This vignette
is a short introduction to {cryptoQuotes}, for a
more extensive introduction on its usecase and limitations please refer
to the wiki.
NOTE: This
vignette
is limited by geolocation due to various country specific cryptocurrency laws. The introduction, therefore, is limited to what is available in the US.
Throughout this vignette
we will explore the Bitcoin
market data using the Kraken
exchange. All available
tickers
and its notation various across exchangs, so if you
are unfamiliar with the exchange specific notation please use the
available_intervals()
-functions,
# show a sample of
# the available tickers
sample(
x = available_tickers(
source = "kraken",
futures = FALSE
),
size = 5
)
#> [1] "DASHUSD" "MCEUR" "NTRNUSD" "ARPAUSD" "PAXGUSD"
These available tickers can be passed into the
ticker
-argument of all the get_*
-functions
with the appropriate source
and
futures
-argument which, in this case, is
kraken
and FALSE
.
Cryptocurrency market data in R
Open, High, Low, Close an Volume
We will extract the Bitcoin market data in hourly
intervals, and store it as BTC
,
## extract Bitcoin
## market on the hourly
## chart
BTC <- get_quote(
ticker = "XBTUSDT",
source = "kraken",
futures = FALSE,
interval = "1h"
)
#> open high low close volume
#> 2025-01-12 23:00:00 93921.4 94514.1 93921.4 94514.1 0.5312528
#> 2025-01-13 00:00:00 94514.1 95842.5 94476.1 95298.0 6.5573938
#> 2025-01-13 01:00:00 95324.3 95350.4 94155.7 94215.0 1.9518172
#> 2025-01-13 02:00:00 94217.0 94441.1 93963.5 94200.4 0.4674782
#> 2025-01-13 03:00:00 94200.9 94383.4 94023.9 94262.0 5.2429623
#> 2025-01-13 04:00:00 94244.7 94833.9 94202.6 94671.1 0.2453315
The market data can be extracted in different intervals using the
interval
-argument. To see available intervals, the
available_intervals()
-function can be used,
## get available
## intervals for OHLC
## on Kraken
available_intervals(
source = "kraken",
type = "ohlc",
futures = FALSE
)
#> ℹ Available Intervals at "kraken" (spot):
#> ✔ 1m, 5m, 15m, 30m, 1h, 4h, 1d, 1w, 2w
Sentiment Data
To put the Bitcoin price action in perspective, an interesting
sentiment indicator like the long
to short
ratio can be extracted,
## extract long-short
## ratio on Bitcoin
## using the hourly chart
LS_BTC <- try(
get_lsratio(
ticker = "XBTUSDT",
source = "kraken",
interval = "1h"
)
)
#> Error in base::tryCatch(base::withCallingHandlers({ :
#> ✖ Couldn't find "XBTUSDT" on "kraken".
#> ✔ Run available_tickers(source = 'kraken', futures = TRUE) to see available
#> tickers.
#> ℹ If the error persists please submit a bug report.
This gives an error
. The source of the error is the
ticker-naming convention; as the long-short ratio is specific
to the perpetual futures market, and the current ticker is specific to
the spot-market, the endpoint throws an error.
To circumvent this, we can either use perpetual futures throughout
the script
, or modify the ticker
-argument as
follows,
## extract long-short
## ratio on Bitcoin
## using the hourly chart
LS_BTC <- get_lsratio(
ticker = "PF_XBTUSD",
source = "kraken",
interval = "1h"
)
#> long short ls_ratio
#> 2025-01-12 23:00:00 0.7440 0.2560 2.906250
#> 2025-01-13 00:00:00 0.7451 0.2549 2.923107
#> 2025-01-13 01:00:00 0.7430 0.2570 2.891051
#> 2025-01-13 02:00:00 0.7418 0.2582 2.872967
#> 2025-01-13 03:00:00 0.7434 0.2566 2.897116
#> 2025-01-13 04:00:00 0.7443 0.2557 2.910833
The ticker
specific to the perpetual futures market can
be extracted using the available_tickers
with
futures = TRUE
as follows,
# show a sample of
# the available tickers
sample(
x = available_tickers(
source = "kraken",
futures = TRUE
),
size = 5
)
#> [1] "PF_ATHUSD" "PF_MKRUSD" "PF_MERLUSD" "FF_SOLUSD_250131"
#> [5] "PF_REEFUSD"
Charting cryptocurrency market data
The Bitcoin market data can be charted using the
chart()
-function, which uses {plotly} as backend,
# candlestick chart with
# volume and Long to Short Ratio
chart(
ticker = BTC,
main = kline(),
sub = list(
volume(),
lsr(ratio = LS_BTC)
),
options = list(
dark = FALSE
)
)
Adding indicators
{cryptoQuotes}
also acts as an API-client to {TTR}, and supports most
of its functions. We can add Moving Average indicators, and Bollinger
Bands to the chart using the indicator
-argument,