summaryrefslogtreecommitdiffstats
path: root/doc/en/details-investments.docbook
blob: e9cae48cac9cb552058cb8d2043cfe42621b669a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
<?xml version="1.0" encoding="UTF-8"?>
<chapter id="details.investments">
<chapterinfo>
  <authorgroup>
    <author>
      <firstname>Ace</firstname>
      <surname>Jones</surname>
      <affiliation>
        <address><email>acejones@users.sourceforge.net</email></address>
      </affiliation>
    </author>
  </authorgroup>
  <date>2009-06-14</date>
  <releaseinfo>1.0</releaseinfo>
</chapterinfo>

<title>Investments</title>

<sect1 id="details.investments.overview">
<title>Investments in &kappname;</title>

<sect2>
<title>Investments</title>

<para>
  Investments are instruments for investing money that are traded on a market.
  Stocks, bonds, and mutual funds are the most common investments; so they are
  the ones supported most directly.  Futures, commodities, options, and more
  complex derivatives are also sometimes used, but &kappname; has no special
  functionality for them.  As long as they behave like a stock or a bond, they
  can be tracked easily.
</para>
</sect2>

<sect2>
<title>Base Currency</title>
<para>
  Each investment has a Base Currency.  This is the currency in which it is
  traded.  When a price quote is entered for an investment, the currency of the
  value given is always its base currency.  A stock on the NYSE (New York Stock
  Exchange) would be in US dollars, and one on an Australian market would be in
  Australian dollars.
</para>
</sect2>

<sect2>
<title>Investment Accounts</title>
<para>
  Investment Accounts hold a collection of investments.  An Investment account
  contains transactions, such as buys and sells, of those investments.  All
  transactions in an Investment account must relate to a specific investment.
  There is no separate <quote>cash balance</quote> in an investment account.  For
  that, you need a Brokerage Account.
</para>
</sect2>

<sect2>
<title>Brokerage Accounts</title>
<para>
  An investment account often has an associated Brokerage Account.  This is also
  sometimes referred to as a <quote>Cash Account</quote>.  Investment accounts
  cannot contain cash transactions, like a transfer from your bank.  When a
  stock is sold, the proceeds are typically placed in the Brokerage Account.
</para>

<para>
  When you create an Investment Account, you have the option of creating an
  associated Brokerage Account with it.
</para>

</sect2>

</sect1>

<sect1 id="details.investments.investment">
<title>Creating an Investment Account</title>

<para>
  The first step on the path to working with investments is to create an account
  to hold your investments. Choose <menuchoice><guimenu>Account</guimenu>
  <guimenuitem>New account...</guimenuitem></menuchoice> to begin the process of
  adding a new account.  Create an account as usual, making sure to choose
  <quote>Investment</quote> as the type of account.
</para>

<para>
  To work with the new investment account, navigate to the
  <guibutton>Investments</guibutton> view, and choose the account you have just
  created from the <guilabel>Select Account</guilabel> dropdown box.
</para>
</sect1>
            
<sect1 id="details.investments.securities">
<title>Adding Investments to Your Account</title>

<para>
  To add individual Investments to your Investment Account, navigate to
  the <guibutton>Investments</guibutton> view, and choose the account where the
  investment is held from the <guilabel>Select Account</guilabel> drop-down box.
</para>

<para>
  Right-click the mouse in the empty space in the view.  This brings up
  the <guimenu>Investment Options</guimenu> context menu. Choose
  <guimenuitem>New...</guimenuitem> from this menu.  This launches the
  <guilabel>New Investment Wizard</guilabel> which you use to create your new
  Investment.
</para>

<sect2 id="details.investments.newinvestmentwizard">
<title>New Investment Wizard</title>

<para>
  The first thing you'll be asked to enter is the type of investment, whether
  it's a stock, bond, etc.
</para>

<para>
  Next, the investment details page is presented.  The following information is
  entered on this page:
</para>

<itemizedlist>
  <listitem><para> Trading Symbol.  The ticker symbol used to identify the
    investment on whatever market it trades.  &kappname; requires a trading
    symbol for all investments; however some investments do not have symbols.
    In this case, you will need to make up a symbol for it.
  </para></listitem>

  <listitem><para> Full name.  The friendly, readable name of the investment
    you're creating, e.g., <quote>Advanced Micro Devices, Inc.</quote> This name is
    also referred to as the security.
  </para></listitem>

  <listitem><para> Fraction.  The degree of precision to which your holdings are
    measured.  For example, in the US most mutual funds measure holdings to
    three decimal places, so you would enter 1000 in this field.  Stocks are
    often measured to only whole units, so you could enter 1 for a stock like
    this.
  </para></listitem>
  
  <listitem><para> Trading market.  Where the stock trades.  This is an optional
    field which is provided for your convenience.  This information is not used
    anywhere else in &kappname;.
  </para></listitem>

  <listitem><para>Identification.  An optional field to enter additional
    identification information you might like to keep track of.  Again, this
    information is not used anywhere else.
  </para></listitem>

  <listitem><para>Trading currency. The underlying currency in which this
    investment trades on its market.
  </para></listitem>

  <listitem><para> Price entry. Choose whether the price will be entered as an
    individual price, or as the total for all shares.
  </para></listitem>
</itemizedlist>

<para>
  If you are using Online Quotes, ensure that the symbol exactly matches the
  symbol used by your quote source.  Yahoo covers most of the world's markets,
  and requires a suffix on the end of symbols outside the US.  For example,
  Rubicon Limited on the New Zealand market should be entered as
  <quote>RBC.NZ</quote>.
</para>

<para>
  Finally, you're presented with the Online Update screen.  This is where you
  tell &kappname; how you would like to update the prices of your investment.
  The following items are set here:
</para>

<itemizedlist>
  <listitem>
    <para>
      Use Finance::Quote.  This is an option for GnuCash users who are used to
      this style of quotes.  Most users can leave this unchecked.
    </para>
  </listitem>

  <listitem>
    <para>
      Online Source.  The online source you'd like to use for this particular
      investment.  The most common choice is <quote>Yahoo</quote>.  Try that
      first, and if the investment cannot be found using this source, then
      experiment with the others.
    </para>
  </listitem>

  <listitem>
    <para>
      Factor.  A multiplier that should be applied to quotes retrieved for this
      investment.  This is most commonly needed for UK stocks where the price
      quoted is in pence (1/100), and the stock is denominated in pounds.  In
      this case, enter 0,01 for the Factor.
    </para>
  </listitem>
</itemizedlist>
</sect2>
</sect1>

<sect1 id="details.investments.edit">
<title>Editing an Investment</title>

<para>
  The Investment view window lists your current holdings in this account, along
  with their symbol, value, and price.  Right-click the mouse on any of the
  investments to bring up the <guimenu>Investment Options</guimenu> context
  menu, where you have the option to add, edit, or delete individual investments
  from this account. Also, you can update the price of your investments here
  either manually or via their online source. In addition, it is possible to
  close an empty account, or to reopen a closed account.
</para>
</sect1>

<sect1 id="details.investments.ledger">
<title>Investment Transactions</title>

<para>
	<screenshot>
	<screeninfo>Investment Transaction Form</screeninfo>
	<mediaobject>
	<imageobject>
	<imagedata fileref="investment-transactionform.png" format="PNG" />
	</imageobject>
	<textobject>
	<phrase>Investment Transaction Form</phrase>
	</textobject>
	</mediaobject>
	</screenshot>
</para>

<para>
  Investment transactions are entered and edited in the
  <link linkend="details.ledgers">ledger</link> view, as with other kinds of
  accounts. However, the fields are different, and vary depending on the
  investment transaction type or activity.  Investment transactions have some
  additional elements:
</para>

<itemizedlist>
	<listitem><para>Activity</para></listitem>
	<listitem><para>Security</para></listitem>
	<listitem><para>Account</para></listitem>
	<listitem><para>Shares, Price, &amp; Total Amount</para></listitem>
	<listitem><para>Fees</para></listitem>
	<listitem><para>Interest category</para></listitem>
</itemizedlist>

<sect2>
<title>Activity</title>
<para>
  The Activity for an investment transaction describes what action is happening
  to the stock.  The following activities are supported:
</para>

<itemizedlist>
  <listitem>
    <para>
      Buy/Sell.  Use to record purchases or sales of individual investments.
      This action requires an account to transfer the funds from/to.
    </para>
  </listitem>

  <listitem>
    <para>
      Dividend/Yield.  Also known as a <quote>Cash Dividend</quote>, this action
      is used for when you receive an interest or dividend disbursement from
      your investment. This action requires an account to transfer the funds
      from/to.
    </para>
  </listitem>

  <listitem>
    <para>
      Reinvest Dividend.  This is a dividend where the proceeds are re-invested
      back into the investment.
    </para>
  </listitem>

  <listitem>
    <para>
      Add/Remove Shares.  A simple increase or decrease in your balance.  This
      should be used very rarely, because it's uncommon for shares to just show
      up in your account (or disappear) unless it's a purchase or a sale.
    </para>
  </listitem>

  <listitem>
    <para>
      Split Shares.  Used when the stock is split.  Enter the ratio of the split
      in the <quote>Split Ratio</quote> field.  For example, in a 3:2 split,
      enter 1.5
    </para>
  </listitem>
</itemizedlist>
</sect2>

<sect2>
<title>Security</title>
<para>
  Each investment transaction must be associated with an individual security,
  which is here just another name for an investment.  Choose the investment name
  when adding or editing a transaction.  The symbol will be displayed when
  viewing it.
</para>
</sect2>

<sect2>
<title>Account</title>
<para>
  For any transactions which generate or require money, you must enter the
  account where the money is transferred to/from.  If your investment account
  has an associated brokerage account, it's usually best to transfer the funds
  there.  This applies to funds for purchase or sale of the investment, as well
  as for fees paid or interest or dividends earned.
</para>
</sect2>

<sect2>
<title>Shares, Price &amp; Total Amount</title>
<para>
  For buy, sell, and cash dividend transactions, the number of shares, the price
  per share, and the total amount of the transaction must be established.  You
  can enter any two of these, and &kappname; will calculate the third.  It's
  usually best to enter just the total amount and the number of shares, because
  these are the known facts of the transaction.  The price per share can be
  calculated from these.
</para>
</sect2>

<sect2>
<title>Fees</title>
<para>
  With many investment transactions you can include the fees (or commission) you
  paid the broker.  If you enter a category for the fee, then a field will be
  shown to the right where you can enter the amount of the fee.  If you need to
  enter more than one fee for the transaction, you can use
  the <link linkend="details.ledgers.split">Split Transactions</link> feature.
  In this case, when you complete entering all the splits, the total amount of
  the fees will be shown to the right.
</para>
</sect2>

<sect2>
<title>Interest</title>
<para>
  This is how you enter an interest or dividend payment from an invenstment.  As
  with fees, if  you enter a category, then  a field will be shown  to the right
  where  you can  enter the  amount.   You can  also use  the split  transaction
  feature, if required.
</para>
</sect2>

</sect1>

<sect1 id="details.investments.foreign">
<title>Working With Foreign Investments</title>

<para>
  &kappname; supports multiple currencies and investments, and you may want to
  combine the two.  However, doing so requires extra care.  As noted above, when
  you added an investment, you had to specify its trading currency.  This might
  not be the same as your base currency, and it also might not be the same as
  the account in which you hold the stock or the account where you transfer your
  funds to/from for buys/sells.
</para>

<para>
  Consider a hypothetical case.  Your base currency is USD.  You have an
  investment account in EUR, and a brokerage account also in EUR.  In that
  account, you hold shares of TietoEnator, which is traded in SEK.
</para>

<para>
  When you enter a buy transaction on this investment, use SEK as the currency.
  So if you buy 100 shares at a price of SEK 248.00, for a total of SEK
  24,800.00, enter these values in the transaction.
</para>

<para>
	<screenshot>
	<screeninfo>Currency Warning</screeninfo>
	<mediaobject>
	<imageobject>
	<imagedata fileref="investment-currencywarning.png" format="PNG" />
	</imageobject>
	<textobject>
	<phrase>Currency Warning</phrase>
	</textobject>
	</mediaobject>
	</screenshot>
</para>

<para>
  When you choose the brokerage account to fund the transfer, you'll be warned
  that it's in a different currency.
</para>

<para>
	<screenshot>
	<screeninfo>Exchange Rate Editor</screeninfo>
	<mediaobject>
	<imageobject>
	<imagedata fileref="investment-exchangerateeditor.png" format="PNG" />
	</imageobject>
	<textobject>
	<phrase>Exchange Rate Editor</phrase>
	</textobject>
	</mediaobject>
	</screenshot>
</para>

<para>
  When you finish the transaction, you will be prompted for a price update to
  the investment account's currency, in this case, SEK -> EUR.  Review the
  documentation on <link linkend="details.currencies.prices">Entering Prices
  Manually</link> for more information on the price dialog.
</para>

<para>
  If you then switch over to the brokerage account, you will see the transaction
  as EUR 2,254.54, assuming an exchange rate is 11.0000 SEK / EUR.
</para>
</sect1>

<sect1 id="details.investments.prices">
<title>Updating Prices</title>
<para>
  There are two ways of updating the prices for your investments.  You can
  either enter the new price manually or have &kappname; fetch it from the web.

</para>

<sect2>
<title>Manual Price Updates</title>
<para>
  You can enter prices for your investments using the same
  <link linkend="details.currencies.prices">Price Editor</link> as used for
  currencies.
</para>
</sect2>

<sect2 id="details.investments.onlinequotes">
<title>Online Price Quotes</title>
<para>
  &kappname; has the ability to download the latest prices for your investments
  and currencies via the web.  
</para>

<sect3>
<title>How Online Quotes Work</title>
<para>
  At your request, &kappname; will fetch a page from the web that contains the
  latest price for each item.  By default, prices are fetched from
  http://finance.yahoo.com, and are subject to the terms and conditions of that
  site.
</para>

<para>
  The online quote lookup uses the investment's trading symbol to find the
  price.  Therefore, it's important to set the symbol correctly.  Yahoo supports
  stocks from most major world markets, so it's usually just a matter of finding
  the correct symbol.  For example, TietoEnator trades on the Stockholm Stock
  Exchange market, and its Yahoo symbol is TIEN.ST.
</para>

<para>
  To find the trading symbol for a security supported by Yahoo, use the
  <quote>Symbol Lookup</quote> feature at http://finance.yahoo.com.
</para>
</sect3>

<sect3>
<title>Assigning a Quote Source</title>

<para>
  In order to get online price quotes, you first have to enable it for each
  investment or currency you want updated, by setting a <quote>Online Quote
  Source</quote>.  This is the name of the service from which the quote should
  be fetched.  KMyMoney ships with several sources to choose from.  Yahoo is the
  recommended default source, and should work for most investments and all
  currencies.
</para>

<para>
  To assign a quote source to an investment, navigate to the investment summary
  view for the account in which the security is held.  Edit the security by
  right-clicking it and selecting <guimenuitem>Edit Investment
  ...</guimenuitem>.  In the Investment Detail Wizard,
  click <guibutton>Next</guibutton> twice, for the Online Update section.  In
  the Online source dropdown box, select the online source.
</para>

<para>
  Versions of &kappname; starting with 0.9 contain support for the
  Finance::Quote package for obtaining online quotes. This is intended primarily
  as a convenience for those users converting from the GnuCash finance package,
  which uses it as its native method. If you do select this option, you should
  see a different list of sources, those supported by Finance::Quote. If the
  list is empty, it suggests that the package is not properly installed.  See
  their web site at
  <ulink url="http://finance-quote.sourceforge.net">
  http://finance-quote.sourceforge.net</ulink> for more information.
</para>
</sect3>

<sect3>
<title>Adjusting a quote</title>

<para>
  Some online sources do not report the price in a base quantity (e.g., EUR) but
  in a fraction (e.g., Cent). Using this information as price will produce wrong
  values for your investments.
</para>

<para>
  If this is the case for your online source, you can use the
  <guilabel>Factor</guilabel> field to enter an adjusting factor. For the above
  mentioned example the factor would be 0.01.
</para>

<para>
  The <guilabel>Factor</guilabel> field is only available if a
  <guibutton>Quote Source</guibutton> has been selected.
</para>
</sect3>

<sect3>
<title>Fetching Quotes</title>

<para>
  Typically, you will update the prices for all your investments and currencies
  at once.  Choose the <menuchoice><guimenu>Tools</guimenu><guimenuitem>Update
  Stock and Currency Prices...</guimenuitem></menuchoice> menu option to bring
  up the online price quotes dialog.  Press <guibutton>Update All</guibutton> to
  fetch quotes for all investments and currencies in your &kappname; file.
</para>

<para>
	<screenshot>
	<screeninfo>Update Stock and Currency Prices</screeninfo>
	<mediaobject>
	<imageobject>
	<imagedata fileref="investment-onlineupdate.png" format="PNG" />
	</imageobject>
	<textobject>
	<phrase>Online Stock and Currency Price Update</phrase>
	</textobject>
	</mediaobject>
	</screenshot>
</para>
</sect3>

<sect3>
<title>Adding or Editing Quote Sources</title>

<para>
  Adding or editing quote sources is not recommended for anyone but the most
  technical user.  You should feel comfortable reading HTML and writing complex
  regular expressions.  If this doesn't sound like you, we recommend writing to
  the developer's list if none of the quote sources work for you.  Ideally,
  please point us to a web page where these quotes can be obtained.
</para>

<para>
  If you do feel up to the challenge, here's how it works.  The quote sources
  are contained in the settings dialog.
  Choose <menuchoice><guimenu>Settings</guimenu><guimenuitem>Configure
  &kappname;</guimenuitem></menuchoice>.  From there, choose
  the <guilabel>Online Quotes</guilabel> section.  You can choose an existing
  source to edit, or create a new one.  When you are done with your changes, be
  sure to press the <guibutton>Update</guibutton> button before exiting the
  dialog.  Your changes are not saved by default.
</para>

<para>
  The first thing to worry about in an online quote source is the URL.  This is
  the page that is fetched from the web.  You will see a %1 in all sources, and
  a %2 in currency sources.  For investments, %1 is replaced by the trading
  symbol.  For currencies, %1 is replaced by the From currency, and %2 is
  replaced by the To currency.  This URL is then fetched, all HTML tags are
  removed, and that stripped file is then sent to the page parser.
</para>

<para>
  Note that the URL can also be a file: URL, which the quote fetcher takes to
  mean an executable script.  It will pass any command-line arguments to it that
  you have specified, and feed the stdout to the page parser.  For example, you
  might have a script called getquote.sh that contains custom quote logic,
  taking the symbol as a single parameter.  Your URL would be
  <quote>file:/path/to/getquote.sh %1</quote>.
</para>

<para>
  The page parser looks for a symbol, a date, and a price.  Regular expressions
  tell it how to extract those items from the page.  Please review the
  documentation for the <ulink
  url="http://qt.nokia.com/doc/3.3/qregexp.html#1">QRegExp class</ulink> at
  http://qt.nokia.com/doc/3.3/qregexp.html#1 for the exact makeup of the
  regular expressions.  There should be exactly one capture expression,
  surrounded by parentheses, in each regexp.  The date format further tells the
  date parser the order of year, month, and day.  This date format should always
  be in the form "%x %x %x". where x is y, m, or d.  The date parser is very
  smart.  <quote>%m %d %y</quote> will parse <quote>December 31st, 2005</quote>
  as easily as <quote>12/31/05</quote>.  Two digit years are interpreted as
  being in the range of 1950-2049.
</para>
</sect3>
</sect2>
</sect1>

<sect1 id="details.investments.unimplemented">
<title>Unimplemented Features</title>
<para>
  Certain common features that are normally found with investments are not yet
  implemented in &kappname;.  These include: Derivatives (options, futures,
  etc), capital gains, and tax reporting for investments.
</para>
</sect1>
</chapter>