The hardware and bandwidth for this mirror is donated by dogado GmbH, the Webhosting and Full Service-Cloud Provider. Check out our Wordpress Tutorial.
If you wish to report a bug, or if you are interested in having us mirror your free-software or open-source project, please feel free to contact us at mirror[@]dogado.de.
The RHRT package helps you assess Heart Rate Turbulence (HRT) in RR intervals and calculate turbulence onset (TO), slope (TS) and timing (TT). It can plot the tachograms and checks the results for reliability. The ventricular premature beats (VPCs) with coupling (CPI) and compensatory interval (CMI) can either be given with annotations or found on the basis of the filter rules as first described by Grimm et al. 2003. The type of average and order of calculation for all parameters can be set.
This chapter sums up the most common functions and parameters needed when using RHRT.
The core function of RHRT is vectorToHRT
that finds valid VPCs in RR intervals and returns an HRTList
object (see chapter HRTList object for more information):
Every RR interval sequence that matches the needed interval lengths is considered to be a coupling and compensatory interval of a VPC, which can lead to wrong matches. If your data is annotated, you can provide the annotation data with the parameters annotations
and PVCAnn
.
Other parameters are:
numPreRRs
& numPostRRs
are used to modify the filter rules to find HRTs (number of intervals before and after the VPC that have to match the filter criteria).minHRT
is the minimal number of HRTs needed to calculate HRT / create a HRTListnormHallstrom
defines whether TS should be normalised with the method of Hallstrom et al. (see chapter Normalisation).## [1] "HRT0"
Per default getResults
checks whether all needed HRT parameters can be calculated reliably. This is done via a t-test per parameter value (for more information see chapter Reliability Check). If any of the parameter values is not reliable getResults
returns NR (not reliable).
## [1] "HRT0"
In addition to the classification system HRT0-2 RHRT implements HRTA-C that is based on the three parameters TO, TS and TT.
## [1] "HRTA"
With the parameter type
you can choose between getting only the HRT class, all parameter values or the parameter values with the corresponding p-values (types “class”, “parameter” or “full”, respectively).
## TO TS TT
## -10.57551 37.61417 3.00000
Other parameters are:
nTS
: the normalised TS is returned or used for classification instead of TS.num
: forces the function to return numerics when using type = parameter
. Depending on the results and your setting of type
the getResults
returns characters or numerics.pmax
: changes the needed significance level for the parameters to be reliable.Per default the VPCS is zoomed in. If you want to also see the CPI and CMI use cropped = FALSE
.
An HRT object saves the data of one VPCS and its HRT results. It consists of the following slots:
preRRs
: preceding regular intervals, 5 per defaultcouplRR
: CPIcompRR
: CMIpostRRs
: following regular intervals, 15 per defaultTO
TS
TT
nTS
: normalised TS, for more Information see chapter Normalisation of Turbulence Slopeintercept
: The intercept of the TS regression line that is needed for plottingnintercept
: Analogously, the intercept of nTS
getRRs
This function returns all intervals saved in the HRT object. This if helpful for i.e. calculating an averaged VPCS out of a set of HRT objects.
plot
Per default plot
displays a zoomed in plot of the VPCS with highlighted TO and TS and a legend given the rounded HRT parameter values. In addition to the common parameters of graphics.plot the method accepts the following parameters:
cropped
: switches between showing a zoomed in version and the full VPCS including CPI and CMI, the default is TRUE
add
: adds the plot to the current oneTT
: highlights TT and includes it to the legendparamsLegend
: switches between showing and hiding the parameter values in the legend, the default is TRUE
colTO
, colTS
and colTT
determine the colour in which the different parameters are highlighted in the plot (red, blue and purple per default).An HRTList object is created when vectorToHRT
is called. All HRT parameters are calculated automatically in this process and can be called with the getHRTParams
-methods.
The HRTList object sums up all HRTs found in the given dataset. The slots are:
name
: The name of the object if given to vectorToHRT
IL
: the average length of all intervals in the given cleaned vector (see VectorToHRT: Cleaning Input for more information)pos
: the indices of the CPIs as found in the given vectorHRTs
: list of all HRT objects foundavHRT
: an avHRT object averaged from all HRTsRMSSD
: the HRV parameter RMSSD calculated from all intervals in the given cleaned vector (see VectorToHRT: Cleaning Input for more information)calcAvHRT
The function calculates the parameters of the averaged HRT. This is called automatically when using vectorToHRT
with default parameters. If the avHRT should be calculated differently the following options are available:
av
: The function with which averaging should be done: mean
or median
.orTO
and orTS
: sets the order in which TO and TS should be calculated. With avAfter
the parameter is assessed separately for every HRT and averaged afterwards, with avBefore
the intervals of all VPCSs are averaged first and the parameter is assessed afterwards. The default is avAfter
for orTO
and avBefore
for orTS
.IL
: the average interval length that is needed to calculate nTS. The default value is automatically calculated from the whole cleaned vector (see VectorToHRT: Cleaning Input for more information) when calling vectorToHRT
and saved in the IL
slot of the HRTList object.normIL
: the interval length to which the other parameters should be normalised. The default is 800 ms.normHallstrom
: Should nTS be normalised with the method by Hallstrom et al. or just based on the interval length? The default is TRUE
.coTO
, coTS
and coTT
: The cut-off that should be used to calculate the reliability check for the different parameters. The default is coTO
0, coTS
2.5 and coTT
10.getResults
This function returns either the HRT class or the parameter values. You can determine the output with
type
: “class” returns the HRT class (system HRT0-2 or HRTA-C depending on TT
), “parameter” returns the HRT parameters and “full” returns the HRT parameters and the p-values of the reliability check.TT
: Should TT be included in the return? The default is TRUE
.nTS
: Switches between giving TS (default) and nTS.safe
: Per default safe
is TRUE
so only results that are reliable are returned. For not reliable results the function returns “NR” or, if num
is TRUE
, NA
.pmax
: The cut-off of the p-value to determine reliability. Per default this is 0.05.num
: Forces the function to return numerics. Keep in mind that this is inapplicable when using type
“class”, in this case the function gives a warning and returns NA
. With type
“full” num
is ignored, because in that case the result is already numeric.coTO
, coTS
and coTT
: Analogously to calcAvHRT
the cut-off that should be used to determine whether the parameter values are normal. The default is coTO
0, coTS
2.5 and coTT
10. Be sure to give the same cut-offs to calcAvHRT
and getResults
if you don’t use the result, otherwise the p-values won’t match the results.getHRTParams
Returns the values of the given slot of all HRT objects in the HRTList.
This can be used to quickly list all separate HRT parameters of an HRTList
. Although the function name focuses on the HRT parameters, it can return any other slot of the HRT objects.getPositions
Returns the positions of the couplRRs which is identical to HRTList@pos
.plot
Analogously to the plot function of the HRT object HRTList objects can be plotted. This function plots the avHRT and adds the VPCSs of all HRTs as grey lines in the background.An avHRT object is stored in an HRTList and inherits from the HRT object. It is averaged from the other HRTs in the HRTList automatically and can be recalculated with calcAvHRT.
In addition to the HRT slots avHRT stores data about its calculation and the parameter validity:
av
, orTO
and orTS
: for more information see HRTList: Functions (calcAvHRT)pTO
, pTS
, pTT
and pnTS
: p-values from the reliability check, for more information see Reliability ChecknRMSSD
: the RMSSD normalised to the a given heart rate, per default to 75 bpmThis is the core function of the package. It finds VPCs, checks the respective VPCS for validity and saves the results in an HRTList object. Its parameters are
input
: RR interval data that should be searched for HRT. Data formatted as timestamps should be converted before using vectorToHRT
.annotations
: If no annotations are given vectorToHRT
searches for matching patterns of interval lengths in the given vector regardless of any other information in respect to the type of beats. Therefore, the function could also save HRTs based on atrial premature complexes or other arrhythmia if the surrounding intervals match the filter rules (for more information see Methods & Background: Filter Rules). If annotations are given the function only checks the intervals marked to stem from ventricular beats. This leads to more accurate results and speeds up the runtime considerably. The annotations should match the beats at the end of the intervals.PVCAnn
: A character or string with which the VPCs are marked in the annotation vector. The default is “V”.normIL
: The interval length to which the other parameters should be normalised. The default is 800 ms.normHallstrom
: Should nTS be normalised with the method by Hallstrom et al. or just based on the interval length? The default is TRUE
.numPreRRs
and numPostRRs
: The number of regular intervals before and after the CPI and CMI, respectively, on which the filter rules are applied and from which TS and nTS are being calculated. The default is 5 and 15, respectively.inputName
: You can give a name to the HRTList
to easier organise your data. If no name is given, the slot is set with NA
.minHRT
: This sets the minimal amount of HRTs that have to be found. Per default an HRTList
is only created if the vector contains 5 or more HRTs.cleaning
: To calculate IL
and RMSSD
the data is cleaned per default. (for more information see VectorToHRT: Cleaning Input).The IL
and RMSSD
can be highly biased through outliers. Since ECG data can include artefacts, especially at the end and the beginning, RHRT cleans the data before calculating these parameters. Intervals are removed if they
To ensure snippets free of any bias and containing effective VPCs, the VPCSs are filtered based on their interval lengths. The first publication to mention filter rules was Grimm et al.. With little variations these are the criteria that are used in the package as possible VPCSs are only saved as HRT objects if they match the following criteria:
Filter rules for CPI and CMI:
Both intervals are compared to the reference interval (RFI). This interval is calculated as the mean of the preceding intervals before the coupling interval.
Filter rules for regular intervals:
How many preceding and following intervals of CPI and CMI are checked is based on numPreRRs
and numPostRRs
of vectorToHRT
. The default is 5 and 15, respectively. If any of the intervals do not fit the rules, the complete set is neglected.
HRT is influenced by the heart rate. While there is no clear conclusion for TO, TS values clearly positively correlate with the RR interval length (reviewed in Blesius et al. 2020). Therefore, RHRT calculates nTS
that is normalised to a fixed interval length (800 ms per default) in addition to the common TS.
Beside the heart rate, TS is biased by the number of HRTs used to calculate it (reviewed in Blesius et al. 2020). While physiological reasons were suggested for this phenomenon (Cygankiewicz et al. 2004 and Chen 2009), Hallstrom et al. 2004 reasoned it to be a mathematically induced relation based on the number of VPCSs as well as the number of postRRs to determine TS. They proposed a method to normalise TS in which, firstly, TS is normalised to a HR of 75 bpm (which is 800 ms interval length). Here, it makes no mathematical difference whether TS is normalised or the intervals themselves before assessing TS. Secondly, the following formula is used:
nTS = TS - ( 0.02475 * (numPostRRs-2)^0.9449 * (RMSSD / √#VPCSs) )
RHRT uses this normalisation per default. This can be changed with the boolean parameter normHallstrom
in vectorToHRT
and calcAvHRT
.
The HRT parameter values pre se do not give any information about 1) how many VPCSs have been used to determine them and 2) how reliable the values are. However, two identical values are inherently different if one is calculated from a VPCS with a highly varying values and the other from a high amount of VPCS with hardly any variation. Still, HRT classification generally does not take this into account.
RHRT implements a reliability check to give the opportunity to only use HRT parameter values that are reliable to a desired extent. This check consists of a one-sided t-test (t.test
of the stats package) off all separate values against the respective cut-off of the parameter. The resulting p-value implicates the possibility of the classification being true based on being the combination of average and variability of the parameter values and therefore the reliability of the averaged value.
These t-tests are being done automatically during calcAvHRT
which is called by vectorToHRT
. The default values of the cut-offs are 0 for TO
, 2.5 for TS
as well as nTS
and 10 for TT
. getResults
returns the results if reliable. However, it returns all results ignoring the reliability check via the boolean parameter safe
and changes the p-value cut-off with pmax
(0.05 per default).
Keep in mind that the parameter value cut-offs coTO
, coTS
and coTT
are only used to compare the values and classify them. They are not related to the identically named parameters of calcAvHRT
that are used for the t-tests.
The order in which the HRT parameters are calculated has an impact on the resulting values (Chen 2011). Though Schmidt et al. 1999 proposed to first calculate an averaged tachogram and determine TS then and for TO to first assess it from the separate VPCSs and average the results afterwards, the order gets switched in some studies as reviewed in Blesius et al. 2020. Therefore, RHRT gives the opportunity to change the calculation order for TO and TS through the parameters orTO
and orTS
of calcAvHRT
. By default the order is as suggested by Schmidt et al. Additionally with av
you can switch between mean
and median
as averaging function.
The main focus of the package is to determine the HRT parameters or class of a person by a long-term ECG measurement. Load the data as a numeric vector and use vectorToHRT
to find HRTs, then getResults
and plot
to check the results:
hrtl <- vectorToHRT(testdataLong) # create the HRTList
getResults(hrtl) # get the averaged HRT parameters
## [1] "HRT0"
The results do not pass the reliability check so we get “NR” as HRT class. The plot shows that firstly TO is near to zero and secondly there is a high variability in the VPCSs. We can go deeper into the data by checking the exact parameters (including TT as an additional hint to the person’s status) and zooming out of the plot:
round(
getResults(hrtl, "full", TT = TRUE),
digits = 2) # get the parameters and p-values of the variability check
## TO TS TT pTO pTS pTT
## -10.58 37.61 3.00 0.00 0.00 0.00
As expected TO is not reliable with a p-value over 0.05. The VPCSs still seem to fluctuate a lot with the first two postRRs that determine TO varying above and below the ones of the avHRT. We can can get a picture on all TO values by using getHRTParams
:
## [1] -12.264829 -6.349883 -11.856998 -9.011983 -13.733660 -10.859878
## [7] -10.357064 -13.174994 -12.743754 -8.427299 -11.495815 -8.892588
## [13] -11.795365 -6.502960 -11.165541
## Min. 1st Qu. Median Mean 3rd Qu. Max.
## -13.734 -12.061 -11.166 -10.576 -8.952 -6.350
These results can help to come to a well-founded decision on whether to classify the patient as HRT0/HRTA and trust the TO value or rather classify them conservatively as HRT1/HRTB.
This is an example how the package can be used to analyse the HRT methodology. Due to data size we use a set of HRTs of one person rather than a set of averaged HRTs. For example, we can compare the difference in TS
values when using different numPostRRs
.
hrtl10 <- getHRTParams(vectorToHRT(testdataLong, numPostRRs = 10), "TS")
hrtl20 <- getHRTParams(vectorToHRT(testdataLong, numPostRRs = 20), "TS")
boxplot(hrtl10, hrtl20, names = c("TSRR = 10", "TSRR = 20"))
##
## Welch Two Sample t-test
##
## data: hrtl10 and hrtl20
## t = 0, df = 28, p-value = 1
## alternative hypothesis: true difference in means is not equal to 0
## 95 percent confidence interval:
## -5.116392 5.116392
## sample estimates:
## mean of x mean of y
## 39.36397 39.36397
These binaries (installable software) and packages are in development.
They may not be fully stable and should be used with caution. We make no claims about them.
Health stats visible at Monitor.