This document demonstrates how to use the xvm package and its functions with sample datasets and plots. It also shows how to read multiple xvg files and arrange their plots using ggpubr.
Note: Ensure dependency packages are installed:
Load the xvm package:
Load other dependency packages:
Retrieve the path to the example file included in the package:
# Read the xvg file using read_xvg() function
rmsd_data <- read_xvg(rmsd_file_path)
# The imported xvg file is stored as a list, with the list name corresponding to the file name.
names(rmsd_data)
#> [1] "rmsd.xvg"The imported xvg file is stored as a list, so you can simply display
the data using the str() function.
str(rmsd_data[[1]])
#> List of 2
#>  $ data    :'data.frame':    3334 obs. of  2 variables:
#>   ..$ Time (ps): num [1:3334] 0 30 60 90 120 150 180 210 240 270 ...
#>   ..$ RMSD (nm): num [1:3334] 0.000499 0.115534 0.127646 0.125452 0.123716 ...
#>  $ metadata:List of 9
#>   ..$ title            : chr "RMSD"
#>   ..$ subtitle         : chr "Backbone after lsq fit to Backbone"
#>   ..$ xaxis            : chr "Time (ps)"
#>   ..$ yaxis            : chr "RMSD (nm)"
#>   ..$ xaxis_formatted  : chr "Time (ps)"
#>   ..$ yaxis_formatted  : chr "RMSD (nm)"
#>   ..$ legends          : chr(0) 
#>   ..$ legends_formatted: Named list()
#>   ..$ file_path        : chr "/private/var/folders/_b/gx4lc14d5ssf7pl9qlkl32r80000gn/T/Rtmp7dsKbS/Rinstc47b2d226cbf/xvm/extdata/rmsd.xvg"
#>  - attr(*, "class")= chr "xvg_data"The list contains two elements, each storing different pieces of information:
$data: a data frame containing the xvg data.
$metadata: other detailed information about the xvg
file, including:
The read_xvg() function can accept multiple xvg file
paths as a character vector.
# Similarly, you can also read multiple types of xvg files. 
multi_file_path <- dir(system.file("extdata", package = "xvm"))
# Filter out xvg files using stringr package
library(stringr)
multi_file_path <- multi_file_path[str_detect(multi_file_path, ".xvg")]
print(multi_file_path)
#> [1] "rmsd.xvg" "rmsf.xvg"
# Set the full xvg file paths
multi_file_path <- file.path(system.file("extdata", package = "xvm"),
                             multi_file_path
                             )You can view the information of a single xvg file by indexing the list:
# Check the first xvg file info via indexing
str(multi_data[[1]])
#> List of 2
#>  $ data    :'data.frame':    3334 obs. of  2 variables:
#>   ..$ Time (ps): num [1:3334] 0 30 60 90 120 150 180 210 240 270 ...
#>   ..$ RMSD (nm): num [1:3334] 0.000499 0.115534 0.127646 0.125452 0.123716 ...
#>  $ metadata:List of 9
#>   ..$ title            : chr "RMSD"
#>   ..$ subtitle         : chr "Backbone after lsq fit to Backbone"
#>   ..$ xaxis            : chr "Time (ps)"
#>   ..$ yaxis            : chr "RMSD (nm)"
#>   ..$ xaxis_formatted  : chr "Time (ps)"
#>   ..$ yaxis_formatted  : chr "RMSD (nm)"
#>   ..$ legends          : chr(0) 
#>   ..$ legends_formatted: Named list()
#>   ..$ file_path        : chr "/private/var/folders/_b/gx4lc14d5ssf7pl9qlkl32r80000gn/T/Rtmp7dsKbS/Rinstc47b2d226cbf/xvm/extdata/rmsd.xvg"
#>  - attr(*, "class")= chr "xvg_data"Alternatively, use lapply() to generate plots for each
xvg file: