From 4b309bd0b613791dc77f10623149374b87556c45 Mon Sep 17 00:00:00 2001 From: Joselyn Chavez Date: Mon, 28 Oct 2024 22:22:45 -0400 Subject: [PATCH] update --- 02_sesion2.Rmd | 261 ++++++++++++- .../figure-html/unnamed-chunk-61-1.png | Bin 99581 -> 91279 bytes docs/404.html | 9 + .../figure-html/unnamed-chunk-61-1.png | Bin 0 -> 91279 bytes ...63n-e-instalaci\303\263n-de-paquetes.html" | 37 +- ...rol-de-versiones-con-github-y-rstudio.html | 9 + ...i\303\263n-de-sitios-web-con-pkgdown.html" | 201 +++++----- "docs/creaci\303\263n-de-vi\303\261etas.html" | 15 +- ...ando-la-infraestructura-de-un-paquete.html | 9 + docs/creando-mis-primeras-funciones.html | 228 +++++++++++- "docs/dise\303\261o-de-pruebas.html" | 9 + "docs/documentaci\303\263n-de-funciones.html" | 343 +++++++++--------- docs/index.html | 9 + docs/proyectos-colaborativos-1.html | 9 + docs/reference-keys.txt | 9 + docs/search_index.json | 2 +- ...las-versiones-de-paquetes-de-rstudio.html" | 9 + docs/trabajando-con-proyectos-de-rstudio.html | 9 + 18 files changed, 884 insertions(+), 284 deletions(-) create mode 100644 docs/_main_files/figure-html/unnamed-chunk-61-1.png diff --git a/02_sesion2.Rmd b/02_sesion2.Rmd index 5c38ac6..79ea836 100644 --- a/02_sesion2.Rmd +++ b/02_sesion2.Rmd @@ -8,6 +8,263 @@ Instructora: Joselyn Chávez [ ```{r,echo=FALSE} -knitr::include_url("https://comunidadbioinfo.github.io/cdsb2023/solucion_problemas.html", height = "380px") +knitr::include_url("https://comunidadbioinfo.github.io/cdsb2024/creando_funciones.html", height = "380px") ``` -](https://comunidadbioinfo.github.io/cdsb2023/solucion_problemas.html) +](https://comunidadbioinfo.github.io/cdsb2024/creando_funciones.html) + +## Nombre de la función + +- Cortos pero descriptivos +- Recomendable: Separar las palabras con _ +- Establecer una palabra en común al inicio para familias de funciones + +```{r, eval=FALSE} +use_bioc_citation() # es mejor que + +citation() +bioc_cit() +usebioccitation() +useBiocCitation() +use.bioc.citation() +``` + +## Estructura de la función + +- Indentar las líneas de código. +- Agregar comentarios para separar/describir las secciones importantes. +- Usar la sintaxis paquete::funcion() cuando hacemos llamado a funciones de otros paquetes. + +```{r, eval=FALSE} +usethis::use_r("subset_heatmap") +``` + +Generemos el código de manera regular. + +Simulemos una matriz con diversas mediciones y grafiquemos los datos en un heatmap. + +```{r, message=FALSE, error=FALSE, fig.align='center'} +mi_matriz <- matrix(rnorm(100), nrow = 10) +rownames(mi_matriz) <- paste0("medicion_",letters[1:10]) +colnames(mi_matriz) <- paste0("grupo_",letters[1:10]) + +library(ComplexHeatmap) + +Heatmap(mi_matriz, + cluster_columns = FALSE, + heatmap_legend_param = list(title = "valores")) +``` + +Escribamos una función que permita seleccionar algunos grupos de interés y genere el heatmap. + +No la mejor opción: + +```{r, eval=FALSE} +library(ComplexHeatmap) + +subset_heatmap <- function(x,mediciones=NULL,grupos=NULL) { +x_subset <- x[mediciones,grupos] +Heatmap(mi_matriz, + cluster_columns=FALSE, + heatmap_legend_param=list(title="valores")) +} +``` + +Un poco mejor: + +```{r, eval=FALSE} +library(ComplexHeatmap) +subset_heatmap <- function(x, mediciones = NULL, + grupos = NULL) { + x_subset <- x[mediciones,grupos] + Heatmap(mi_matriz, + cluster_columns = FALSE, + heatmap_legend_param = list(title = "valores")) +} +``` + +Mucho mejor: + +```{r, eval=FALSE} +subset_heatmap <- function(x, mediciones = NULL, + grupos = NULL) { + # subset matrix + x_subset <- x[mediciones, grupos] + + # plot heatmap + ComplexHeatmap::Heatmap( + x_subset, + cluster_columns = FALSE, + heatmap_legend_param = list(title = "valores")) +} +``` + +Ejecutemos la función: + +```{r, eval=FALSE} +subset_heatmap( + mi_matriz, + mediciones = c("medicion_a", "medicion_b", "medicion_c"), + grupos = c("grupo_d","grupo_e","grupo_f")) +``` + +## ¡Tu turno! + +Escribe una función que: + +- Filtre la matriz y mantenga sólo los valores por encima de cierto valor. +- Genere el heatmap filtrado. + +Recuerda seguir las recomendaciones para escribir funciones. + +## Argumentos + +- Los argumentos deben tener un nombre descriptivo y bien documentado. + +No la mejor opción: + +```{r, eval=FALSE} +subset_heatmap <- function(x, m, g) { + + # subset matrix + x_subset <- x[mediciones, grupos] +} +``` + +Una mejor opción: + +```{r, eval=FALSE} +subset_heatmap <- function(x, mediciones, + grupos) { + # subset matrix + x_subset <- x[mediciones, grupos] + + # plot heatmap + ComplexHeatmap::Heatmap( + x_subset, + cluster_columns = FALSE, + heatmap_legend_param = list(title = "valores")) +} +``` + +- Los argumentos generalmente deben tener valores default. + +```{r, eval=FALSE} +subset_heatmap <- function(x, mediciones = NULL, + grupos = NULL, return_plot = TRUE) { + # subset matrix + x_subset <- x[mediciones, grupos] + + # plot heatmap + ComplexHeatmap::Heatmap( + x_subset, + cluster_columns = FALSE, + heatmap_legend_param = list(title = "valores")) +} +``` + +- Evalúa la validez de los argumentos + +```{r, eval=FALSE} +subset_heatmap <- function(x, mediciones = NULL, + grupos = NULL, return_plot = TRUE) { + + stopifnot(is.matrix(x)) + + # subset matrix + x_subset <- x[mediciones, grupos] + + # plot heatmap + heatmap <- ComplexHeatmap::Heatmap( + x_subset, + cluster_columns = FALSE, + heatmap_legend_param = list(title = "valores")) + + if(return_plot == TRUE) {return(heatmap)} +} +``` + +Este código no debe funcionar: + +```{r, eval=FALSE} +subset_heatmap( + as.data.frame(mi_matriz), + mediciones = c("medicion_a", "medicion_b", "medicion_c"), + grupos = c("grupo_d","grupo_e","grupo_f")) +``` + +Nota: Usa las funciones is() para evaluar la clase de los objects, no uses class() == ni class() !=. + +- Proporciona pistas para entender los errores. + +```{r, eval=FALSE} +subset_heatmap <- function(x, mediciones = NULL, + grupos = NULL, return_plot = TRUE) { + + if(!is.matrix(x)) {stop("x debe ser una matriz")} + + # subset matrix + x_subset <- x[mediciones, grupos] + + # plot heatmap + heatmap <- ComplexHeatmap::Heatmap( + x_subset, + cluster_columns = FALSE, + heatmap_legend_param = list(title = "valores")) + + if(return_plot == TRUE) {return(heatmap)} +} +``` + +Este código debe dar un error, más un mensaje de ayuda. + +```{r, eval=FALSE} +subset_heatmap( + as.data.frame(mi_matriz), + mediciones = c("medicion_a", "medicion_b", "medicion_c"), + grupos = c("grupo_d","grupo_e","grupo_f")) +``` + +## ¡Tu turno! + +- Agrega pasos de evaluación para los otros argumentos de la función. +- Incluye mensajes de ayuda cuando el formato de los argumentos no es el esperado. + +## Indentación + +- Usa 4 espacios para indentar, evita los tabs. +- No uses líneas de más de 80 caracteres. + +## Uso de espacios + +- Usa un espacio después de la coma: a, b, c. +- Usa espacio después de operadores binarios: a == b. + +## Comentarios + +- Usa “##” para comenzar las líneas de comentarios. +- Los comentarios deben usarse como notas y documentación solamente. +- No dejes código comentado que no se va a usar. +- Evita los TODO’s comentados cuando vayas a publicar el paquete. + +## Mensajes para el usuario + +Si deseas imprimir mensajes para el usuario, como el progreso del análisis en la función o advertir sobre los valores de los argumentos, evita el uso de cat(), mejor usa: + +- message() comunica mensajes diagnóstico, como el progreso de la función. + +```{r} +message("Paso 1: completo") +``` + +- warning() comunica situaciones inusuales que pueden ser manejadas por tu código. + +```{r} +warning("El número de elementos esperados es mayor a uno, se tomará el primer valor del vector") +``` + +- stop() indica una condición errónea. + +```{r, eval=FALSE} +stop("x debe ser numérico") +``` + diff --git a/_main_files/figure-html/unnamed-chunk-61-1.png b/_main_files/figure-html/unnamed-chunk-61-1.png index a7776da6d90e7fc7e5396ac7de083fb29428912a..ef58cfd4701a35974fed6ab917f3a149d111a4f0 100644 GIT binary patch literal 91279 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 literal 99581 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

l^)k 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 diff --git a/docs/404.html b/docs/404.html index 2e086cc..feda1b7 100644 --- a/docs/404.html +++ b/docs/404.html @@ -217,6 +217,15 @@

  • 5 Creando mis primeras funciones
  • 6 Documentación de funciones
      diff --git a/docs/_main_files/figure-html/unnamed-chunk-61-1.png b/docs/_main_files/figure-html/unnamed-chunk-61-1.png new file mode 100644 index 0000000000000000000000000000000000000000..ef58cfd4701a35974fed6ab917f3a149d111a4f0 GIT binary patch literal 91279 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 literal 0 HcmV?d00001 diff --git "a/docs/compilaci\303\263n-e-instalaci\303\263n-de-paquetes.html" "b/docs/compilaci\303\263n-e-instalaci\303\263n-de-paquetes.html" index 394f2a9..6cd0b48 100644 --- "a/docs/compilaci\303\263n-e-instalaci\303\263n-de-paquetes.html" +++ "b/docs/compilaci\303\263n-e-instalaci\303\263n-de-paquetes.html" @@ -217,6 +217,15 @@
    • 5 Creando mis primeras funciones
    • 6 Documentación de funciones
        @@ -333,9 +342,9 @@

        9.2 Metadatos de una paquetería<

        9.2.1 Description

        El campo Description describe lo que hace tu paquetería. Suele ser extenso, si requieres escribir múltiples líneas, deben estar indentadas.

        Por ejemplo:

        -
        # Description: Este paquete contiene todas las funciones generadas en el curso 
        -#   de escritura de paqueterías en R. También contiene las funciones que cada 
        -#   participante propuso para solucionar un problema relacionado con su trabajo.
        +
        # Description: Este paquete contiene todas las funciones generadas en el curso 
        +#   de escritura de paqueterías en R. También contiene las funciones que cada 
        +#   participante propuso para solucionar un problema relacionado con su trabajo.

        9.2.2 Dependencias

        @@ -352,14 +361,14 @@

        9.2.2 Dependencias
        Biostrings::translate()

        +
        Biostrings::translate()

        9.2.3 ¿Cómo añadir dependencias?

        • Usando usethis:
        -
        usethis::use_package("ggplot2", type = "Imports")
        +
        usethis::use_package("ggplot2", type = "Imports")
        • Editando manualmente el archivo DESCRIPTION.
        @@ -403,22 +412,22 @@

        9.6 Instalando la última versió
        • Si el paquete se encuentra depositado en CRAN podemos usar la función
        -
        remotes::install_dev("pkgname")
        +
        remotes::install_dev("pkgname")

        Por ejemplo, para instalar la versión en desarrollo de dplyr usaremos el comando

        -
        remotes::install_dev("dplyr") 
        +
        remotes::install_dev("dplyr") 
        • Si el paquete se encuentra en Bioconductor usaremos la siguiente función:
        -
        remotes::install_bioc("pkgname")
        +
        remotes::install_bioc("pkgname")

        Por ejemplo, para instalar la versión en desarrollo de regutools, el paquete desarrollado por miembros de la CDSB, usaremos el comando

        -
        remotes::install_bioc("regutools")
        +
        remotes::install_bioc("regutools")

        9.7 Instalando paquetes desde GitHub

        Para poder instalar un paquete desde GitHub necesitaremos conocer el usuario del creador y el nombre del repositorio.

        -
        remotes::install_github("usuario/repositorio")
        +
        remotes::install_github("usuario/repositorio")

        Por ejemplo, para instalar el paquete starwarssay desarrollado por Erick Cuevas (Erickcufe) utilizaremos el siguiente comando:

        -
        remotes::install_github("Erickcufe/starwarssay")
        +
        remotes::install_github("Erickcufe/starwarssay")

        Independientemente de si el paquete se encuentra en CRAN, Bioconductor, o ninguno de ellos, podemos instalar un paquete depositado en una cuenta de GitHub.

        Para poder instalar un paquete desde GitHub necesitaremos conocer el usuario del creador y el nombre del repositorio donde se encuentra depositado el paquete. Con esta información usaremos la siguiente función:

        @@ -428,15 +437,15 @@

        9.8 Instalando un paquete local

        Paso 1: Abre el proyecto del paquete que estás desarrollando.

      • Paso opcional: Ejecuta la documentación si realizaste algún cambio.

      -
      devtools::document()
      +
      devtools::document()
      • Paso 2: Construye el paquete:
      -
      devtools::build()
      +
      devtools::build()
      • Paso 3: Instala el paquete desde tu proyecto actual:
      -
      devtools::install()
      +
      devtools::install()

      9.9 Contribuyendo código

      diff --git a/docs/control-de-versiones-con-github-y-rstudio.html b/docs/control-de-versiones-con-github-y-rstudio.html index 4aa622e..fbb98f3 100644 --- a/docs/control-de-versiones-con-github-y-rstudio.html +++ b/docs/control-de-versiones-con-github-y-rstudio.html @@ -217,6 +217,15 @@
    • 5 Creando mis primeras funciones
    • 6 Documentación de funciones
        diff --git "a/docs/creaci\303\263n-de-sitios-web-con-pkgdown.html" "b/docs/creaci\303\263n-de-sitios-web-con-pkgdown.html" index bcfa176..dade282 100644 --- "a/docs/creaci\303\263n-de-sitios-web-con-pkgdown.html" +++ "b/docs/creaci\303\263n-de-sitios-web-con-pkgdown.html" @@ -217,6 +217,15 @@
      • 5 Creando mis primeras funciones
      • 6 Documentación de funciones
          @@ -338,23 +347,23 @@

          10.1 Diapositivas

          10.2 Instalación

          -
          install.packages("pkgdown")
          +
          install.packages("pkgdown")

          10.3 Configura el paquete para crear el sitio con pkgdown

          Este paso se ejecuta solamente una vez, dentro del proyecto del paquete.

          -
          usethis::use_pkgdown_github_pages()
          +
          usethis::use_pkgdown_github_pages()

          Este paso genera las acciones automáticas de GitHub para renderizar el sitio. El archivo README.md será tu página de inicio, la documentación en man/ va a crear una sección de referencias, y las viñetas serán renderizadas como articles.

          10.4 Genera la estructura de pkgdown

          Este paso se ejecuta solamente una vez.

          -
          usethis::use_pkgdown()
          +
          usethis::use_pkgdown()

          10.5 Pre-visualiza el sitio de manera local

          Este paso lo puedes ejecutar para visualizar el sitio cada vez que hagas una modificación, antes de enviar los cambios a GitHub.

          -
          pkgdown::build_site()
          +
          pkgdown::build_site()

          10.6 Personalizando el _pkgdown.yml

          @@ -364,14 +373,14 @@

          10.6.1 Metadatos
          url: https://pkgdown.r-lib.org

          +
          url: https://pkgdown.r-lib.org
          • template

          Esta sección permite personalizar la apariencia general del sitio.

          -
          template:
          -  bootstrap: 5
          -  bootswatch: cerulean
          +
          template:
          +  bootstrap: 5
          +  bootswatch: cerulean

          10.6.2 Temas

          @@ -379,31 +388,31 @@

          10.6.2 Temas
          template:
          -  light-switch: true

          +
          template:
          +  light-switch: true
          • Bootswatch themes

          La forma más fácil de cambiar toda la apariencia de tu sitio web es usar un tema de Bootswatch:

          -
          template:
          -  bootstrap: 5
          -  bootswatch: materia
          +
          template:
          +  bootstrap: 5
          +  bootswatch: materia

          Puedes ver los temas disponibles en https://bootswatch.com/

          Estos temas suelen no ser compatibles con el light switch, pero puedes intentar.

          Al cambiar el bootswatch theme necesitas renderizar el sitio para ver por completo los efectos del tema.

          -
          build_site()
          +
          build_site()

          Mientras estás experimentando, puedes acelerar las cosas simplemente reconstruyendo la página de inicio y el CSS ejecutando:

          -
          build_home_index()
          -
          -init_site()
          +
          build_home_index()
          +
          +init_site()

          y luego actualizando el navegador.

          Los bootswatch theme con barras de navegación altas (lux, pulse) también requieren que se modifique la variable pkgdown-nav-height.

          Debido a que los temas de bootswatch son proporcionados por el paquete bslib, se puede anidar el campo bootswatch debajo del campo bslib.

          -
          template:
          -  bootstrap: 5
          -  bslib:
          -    bootswatch: lux
          -    pkgdown-nav-height: 100px
          +
          template:
          +  bootstrap: 5
          +  bslib:
          +    bootswatch: lux
          +    pkgdown-nav-height: 100px
          @@ -414,33 +423,33 @@

          10.7 Las variables bslib
          template:
          -  bootstrap: 5
          -  bslib:
          -    bg: "#202123"
          -    fg: "#B8BCC2"
          -    primary: "#306cc9"

          +
          template:
          +  bootstrap: 5
          +  bslib:
          +    bg: "#202123"
          +    fg: "#B8BCC2"
          +    primary: "#306cc9"

          También se pueden personalizar las fuentes predeterminadas utilizadas para la mayoría del texto (base_font), para los encabezados (heading_font) y para el código (code_font).

          La forma más fácil es proporcionar el nombre de una fuente de Google con la siguiente sintaxis:

          -
          template:
          -  bootstrap: 5
          -  bslib:
          -    base_font: {google: "Roboto"}
          -    heading_font: {google: "Roboto Slab"}
          -    code_font: {google: "JetBrains Mono"}
          +
          template:
          +  bootstrap: 5
          +  bslib:
          +    base_font: {google: "Roboto"}
          +    heading_font: {google: "Roboto Slab"}
          +    code_font: {google: "JetBrains Mono"}

          10.7.1 Syntax highlighting

          Los colores utilizados para el resaltado de sintaxis en bloques de código están controlados por la configuración theme:

          -
          template:
          -  bootstrap: 5
          -  theme: breeze-light
          +
          template:
          +  bootstrap: 5
          +  theme: breeze-light

          Puedes elegir entre: a11y-dark, a11y-light, arrow-dark, arrow-light, atom-one-dark, atom-one-light, ayu-dark, ayu-light, ayu-mirage, breeze-dark, breeze-light, breezedark, dracula, espresso, github-dark, github-light, gruvbox-dark, gruvbox-light, haddock, kate, monochrome-dark, monochrome-light, monochrome, monokai, nord, oblivion, printing, pygments, radical, solarized-dark, solarized-light, solarized, tango, vim-dark, zenburn.

          @@ -449,10 +458,10 @@

          10.8 Layout

          10.8.1 Navbar

          Esta es la estructura default:

          -
          navbar:
          -  structure:
          -    left:  [intro, reference, articles, tutorials, news]
          -    right: [search, github, lightswitch]
          +
          navbar:
          +  structure:
          +    left:  [intro, reference, articles, tutorials, news]
          +    right: [search, github, lightswitch]
          • intro: “Get Started”, enlaza a una viñeta o artículo con el mismo nombre que el paquete.
          • reference: si hay archivos . Rd.
          • @@ -464,33 +473,33 @@

            10.8.1 Navbar
            navbar:
            -  structure:
            -    left:  [search]
            -    right: [reference, articles]

          +
          navbar:
          +  structure:
          +    left:  [search]
          +    right: [reference, articles]

          Puedes usar la misma sintaxis para organizar el menú de artículos:

          -
          navbar:
          - components:
          -   articles:
          -    text: Articles
          -    menu:
          -    - text: Category A
          -    - text: Title A1
          -      href: articles/a1.html
          -    - text: Title A2
          -      href: articles/a2.html
          -    - text: -------
          -    - text: "Category B"
          -    - text: Article B1
          -      href: articles/b1.html
          +
          navbar:
          + components:
          +   articles:
          +    text: Articles
          +    menu:
          +    - text: Category A
          +    - text: Title A1
          +      href: articles/a1.html
          +    - text: Title A2
          +      href: articles/a2.html
          +    - text: -------
          +    - text: "Category B"
          +    - text: Article B1
          +      href: articles/b1.html
          +
          footer:
          +  structure: 
          +    left: pkgdown
          +    right: [developed_by, legal]
          +  components:
          +    legal: Provided without **any warranty**.
          @@ -515,17 +524,17 @@

          10.9.1 Coloreshttps://wave.webaim.org.

        • El color default genera un contraste demasiado bajo contra el fondo gris pálido de la barra de navegación. Este color viene de la paleta “danger” de bootstrap, así que puedes arreglarlo sobreescribiendo esa variable en tu _pkgdown.yml:

        -
        template:
        -  bootstrap: 5
        -  bslib:
        -    danger: "#A6081A"
        +
        template:
        +  bootstrap: 5
        +  bslib:
        +    danger: "#A6081A"
        • Si utilizas entradas de barra de navegación personalizadas que sólo muestran un icono, asegúrate de utilizar también el campo aria-label para proporcionar una etiqueta accesible que describa el icono.
        -
        cran:
        -  icon: fab fa-r-project
        -  href: https://cloud.r-project.org/package=pkgdown
        -  aria-label: View on CRAN
        +
        cran:
        +  icon: fab fa-r-project
        +  href: https://cloud.r-project.org/package=pkgdown
        +  aria-label: View on CRAN

        10.9.2 Imágenes

        @@ -549,18 +558,18 @@

        10.11 La página de referenciasLista de temas definidos por un campo de contenido.

      Mientras editas el índice de referencias, puedes ejecuar la siguiente función para renderizar solamente el índice, lo que permite ver de forma rápida el efecto de los cambios sin tener que renderizar todo el sitio.

      -
      pkgdown::build_reference_index()
      -
      reference:
      -- title: "Connecting to Spark"
      -  desc: >
      -    Functions for installing Spark components and managing
      -    connections to Spark
      -  contents: 
      -  - spark_config
      -  - spark_connect
      -  - spark_disconnect
      -  - spark_install
      -  - spark_log
      +
      pkgdown::build_reference_index()
      +
      reference:
      +- title: "Connecting to Spark"
      +  desc: >
      +    Functions for installing Spark components and managing
      +    connections to Spark
      +  contents: 
      +  - spark_config
      +  - spark_connect
      +  - spark_disconnect
      +  - spark_install
      +  - spark_log

      10.12 Articles

      @@ -571,11 +580,11 @@

      10.12 Articles10.13 News

      Si el archivo NEWS.md está presente, se procesará en un changelog de una sola página basado en los títulos de las secciones del archivo.

      pkgdown asume que el archivo NEWS.md está formateado con encabezados de nivel uno (#) para especificar el nombre del paquete y el número de versión, y con encabezados de nivel dos (##) para proporcionar una organización temática para cada versión.

      -
      # pkgdown 1.1.0
      -
      -## Bug Fixes
      -
      -* Lots of them
      +
      # pkgdown 1.1.0
      +
      +## Bug Fixes
      +
      +* Lots of them

      10.14 Publicando el sitio web

      diff --git "a/docs/creaci\303\263n-de-vi\303\261etas.html" "b/docs/creaci\303\263n-de-vi\303\261etas.html" index 7bb6668..e1f799e 100644 --- "a/docs/creaci\303\263n-de-vi\303\261etas.html" +++ "b/docs/creaci\303\263n-de-vi\303\261etas.html" @@ -217,6 +217,15 @@
    • 5 Creando mis primeras funciones
    • 6 Documentación de funciones
        @@ -343,11 +352,11 @@

        8.3 Características de una vigne

        8.4 ¿Cómo consultar la viñeta de un paquete?

        -
        browseVignettes(package = "ggplot2")
        +
        browseVignettes(package = "ggplot2")

        8.5 ¿Cómo crear una viñeta?

        -
        biocthis::use_bioc_vignette("mi_vignette")
        +
        biocthis::use_bioc_vignette("mi_vignette")

        Esta función tendrá tres efectos:

        • Generar el directorio vignettes en caso que no exista.
        • @@ -358,7 +367,7 @@

          8.5 ¿Cómo crear una viñeta?

          8.6 ¿Cómo guardar y actualizar la viñeta?

          Una vez que se ha generado el archivo vignettes/mi_vignette.Rmd se hacen las modificaciones necesarias. Puedes usar el comando:

          -
          edit_file("vignettes/mi_vignette.Rmd")
          +
          edit_file("vignettes/mi_vignette.Rmd")

          Para guardar los cambios debes hacer click en el botón Knit o utiliza la combinación de teclas Ctrl/Cmd-Shift-K.

        diff --git a/docs/creando-la-infraestructura-de-un-paquete.html b/docs/creando-la-infraestructura-de-un-paquete.html index 3e0e8f7..42fd8db 100644 --- a/docs/creando-la-infraestructura-de-un-paquete.html +++ b/docs/creando-la-infraestructura-de-un-paquete.html @@ -217,6 +217,15 @@
      • 5 Creando mis primeras funciones
      • 6 Documentación de funciones
          diff --git a/docs/creando-mis-primeras-funciones.html b/docs/creando-mis-primeras-funciones.html index cee144b..e3f49cd 100644 --- a/docs/creando-mis-primeras-funciones.html +++ b/docs/creando-mis-primeras-funciones.html @@ -217,6 +217,15 @@
        • 5 Creando mis primeras funciones
        • 6 Documentación de funciones
            @@ -324,7 +333,224 @@

            5 Creando mis primeras funciones<

            29 de octubre de 2024

            5.1 Diapositivas

            -

            +

            +
            +
            +

            5.2 Nombre de la función

            +
              +
            • Cortos pero descriptivos
            • +
            • Recomendable: Separar las palabras con _
            • +
            • Establecer una palabra en común al inicio para familias de funciones
            • +
            +
            use_bioc_citation() # es mejor que
            +
            +citation()
            +bioc_cit()
            +usebioccitation()
            +useBiocCitation()
            +use.bioc.citation()
            +
            +
            +

            5.3 Estructura de la función

            +
              +
            • Indentar las líneas de código.
            • +
            • Agregar comentarios para separar/describir las secciones importantes.
            • +
            • Usar la sintaxis paquete::funcion() cuando hacemos llamado a funciones de otros paquetes.
            • +
            +
            usethis::use_r("subset_heatmap")
            +

            Generemos el código de manera regular.

            +

            Simulemos una matriz con diversas mediciones y grafiquemos los datos en un heatmap.

            +
            mi_matriz <- matrix(rnorm(100), nrow = 10)
            +rownames(mi_matriz) <- paste0("medicion_",letters[1:10])
            +colnames(mi_matriz) <- paste0("grupo_",letters[1:10])
            +
            +library(ComplexHeatmap)
            +
            +Heatmap(mi_matriz,
            +        cluster_columns = FALSE,
            +        heatmap_legend_param = list(title = "valores"))
            +

            +

            Escribamos una función que permita seleccionar algunos grupos de interés y genere el heatmap.

            +

            No la mejor opción:

            +
            library(ComplexHeatmap)
            +
            +subset_heatmap <- function(x,mediciones=NULL,grupos=NULL) {
            +x_subset <- x[mediciones,grupos]
            +Heatmap(mi_matriz,
            +        cluster_columns=FALSE,
            +        heatmap_legend_param=list(title="valores"))
            +}
            +

            Un poco mejor:

            +
            library(ComplexHeatmap)
            +subset_heatmap <- function(x, mediciones = NULL, 
            +                           grupos = NULL) {
            +    x_subset <- x[mediciones,grupos]
            +    Heatmap(mi_matriz,
            +            cluster_columns = FALSE,
            +            heatmap_legend_param = list(title = "valores"))
            +}
            +

            Mucho mejor:

            +
            subset_heatmap <- function(x, mediciones = NULL, 
            +                           grupos = NULL) {
            +    # subset matrix
            +    x_subset <- x[mediciones, grupos]
            +    
            +    # plot heatmap
            +    ComplexHeatmap::Heatmap(
            +      x_subset,
            +      cluster_columns = FALSE,
            +      heatmap_legend_param = list(title = "valores"))
            +}
            +

            Ejecutemos la función:

            +
            subset_heatmap(
            +  mi_matriz,
            +  mediciones = c("medicion_a", "medicion_b", "medicion_c"),
            +  grupos = c("grupo_d","grupo_e","grupo_f"))
            +
            +
            +

            5.4 ¡Tu turno!

            +

            Escribe una función que:

            +
              +
            • Filtre la matriz y mantenga sólo los valores por encima de cierto valor.
            • +
            • Genere el heatmap filtrado.
            • +
            +

            Recuerda seguir las recomendaciones para escribir funciones.

            +
            +
            +

            5.5 Argumentos

            +
              +
            • Los argumentos deben tener un nombre descriptivo y bien documentado.
            • +
            +

            No la mejor opción:

            +
            subset_heatmap <- function(x, m, g) {
            +
            +  # subset matrix
            +    x_subset <- x[mediciones, grupos]
            +}
            +

            Una mejor opción:

            +
            subset_heatmap <- function(x, mediciones, 
            +                           grupos) {
            +    # subset matrix
            +    x_subset <- x[mediciones, grupos]
            +    
            +    # plot heatmap
            +    ComplexHeatmap::Heatmap(
            +      x_subset,
            +      cluster_columns = FALSE,
            +      heatmap_legend_param = list(title = "valores"))
            +}
            +
              +
            • Los argumentos generalmente deben tener valores default.
            • +
            +
            subset_heatmap <- function(x, mediciones = NULL, 
            +                           grupos = NULL, return_plot = TRUE) {
            +    # subset matrix
            +    x_subset <- x[mediciones, grupos]
            +    
            +    # plot heatmap
            +    ComplexHeatmap::Heatmap(
            +      x_subset,
            +      cluster_columns = FALSE,
            +      heatmap_legend_param = list(title = "valores"))
            +}
            +
              +
            • Evalúa la validez de los argumentos
            • +
            +
            subset_heatmap <- function(x, mediciones = NULL, 
            +                           grupos = NULL, return_plot = TRUE) {
            +  
            +    stopifnot(is.matrix(x))
            +  
            +    # subset matrix
            +    x_subset <- x[mediciones, grupos]
            +    
            +    # plot heatmap
            +    heatmap <- ComplexHeatmap::Heatmap(
            +      x_subset,
            +      cluster_columns = FALSE,
            +      heatmap_legend_param = list(title = "valores"))
            +    
            +    if(return_plot == TRUE) {return(heatmap)}
            +}
            +

            Este código no debe funcionar:

            +
            subset_heatmap(
            +    as.data.frame(mi_matriz),
            +    mediciones = c("medicion_a", "medicion_b", "medicion_c"),
            +    grupos = c("grupo_d","grupo_e","grupo_f"))
            +

            Nota: Usa las funciones is() para evaluar la clase de los objects, no uses class() == ni class() !=.

            +
              +
            • Proporciona pistas para entender los errores.
            • +
            +
            subset_heatmap <- function(x, mediciones = NULL, 
            +                           grupos = NULL, return_plot = TRUE) {
            +  
            +    if(!is.matrix(x)) {stop("x debe ser una matriz")}
            +  
            +    # subset matrix
            +    x_subset <- x[mediciones, grupos]
            +    
            +    # plot heatmap
            +    heatmap <- ComplexHeatmap::Heatmap(
            +      x_subset,
            +      cluster_columns = FALSE,
            +      heatmap_legend_param = list(title = "valores"))
            +    
            +    if(return_plot == TRUE) {return(heatmap)}
            +}
            +

            Este código debe dar un error, más un mensaje de ayuda.

            +
            subset_heatmap(
            +    as.data.frame(mi_matriz),
            +    mediciones = c("medicion_a", "medicion_b", "medicion_c"),
            +    grupos = c("grupo_d","grupo_e","grupo_f"))
            +
            +
            +

            5.6 ¡Tu turno!

            +
              +
            • Agrega pasos de evaluación para los otros argumentos de la función.
            • +
            • Incluye mensajes de ayuda cuando el formato de los argumentos no es el esperado.
            • +
            +
            +
            +

            5.7 Indentación

            +
              +
            • Usa 4 espacios para indentar, evita los tabs.
            • +
            • No uses líneas de más de 80 caracteres.
            • +
            +
            +
            +

            5.8 Uso de espacios

            +
              +
            • Usa un espacio después de la coma: a, b, c.
            • +
            • Usa espacio después de operadores binarios: a == b.
            • +
            +
            +
            +

            5.9 Comentarios

            +
              +
            • Usa “##” para comenzar las líneas de comentarios.
            • +
            • Los comentarios deben usarse como notas y documentación solamente.
            • +
            • No dejes código comentado que no se va a usar.
            • +
            • Evita los TODO’s comentados cuando vayas a publicar el paquete.
            • +
            +
            +
            +

            5.10 Mensajes para el usuario

            +

            Si deseas imprimir mensajes para el usuario, como el progreso del análisis en la función o advertir sobre los valores de los argumentos, evita el uso de cat(), mejor usa:

            +
              +
            • message() comunica mensajes diagnóstico, como el progreso de la función.
            • +
            +
            message("Paso 1: completo")
            +
            ## Paso 1: completo
            +
              +
            • warning() comunica situaciones inusuales que pueden ser manejadas por tu código.
            • +
            +
            warning("El número de elementos esperados es mayor a uno, se tomará el primer valor del vector")
            +
            ## Warning: El número de elementos esperados es mayor a uno,
            +## se tomará el primer valor del vector
            +
              +
            • stop() indica una condición errónea.
            • +
            +
            stop("x debe ser numérico")

      • diff --git "a/docs/dise\303\261o-de-pruebas.html" "b/docs/dise\303\261o-de-pruebas.html" index ef5330c..f6fcd5e 100644 --- "a/docs/dise\303\261o-de-pruebas.html" +++ "b/docs/dise\303\261o-de-pruebas.html" @@ -217,6 +217,15 @@
      • 5 Creando mis primeras funciones
      • 6 Documentación de funciones
          diff --git "a/docs/documentaci\303\263n-de-funciones.html" "b/docs/documentaci\303\263n-de-funciones.html" index bd7b33d..dc817d6 100644 --- "a/docs/documentaci\303\263n-de-funciones.html" +++ "b/docs/documentaci\303\263n-de-funciones.html" @@ -217,6 +217,15 @@
        • 5 Creando mis primeras funciones
        • 6 Documentación de funciones
            @@ -367,10 +376,10 @@

            6.5 Antes de empezar…✏️Vamos a crear un función para nuestro paquete. Supongamos que para nuestro paquete necesitamos una función que calcule la moda. Esta es una forma sencilla de calcular la moda:

            -
            getmode <- function(serievector) {
            -  uniqv <- unique(serievector)
            -  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            -}
            +
            getmode <- function(serievector) {
            +  uniqv <- unique(serievector)
            +  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            +}
            • unique(serievector): Crea un vector que contiene únicamente los valores únicos de la serie de números serievector.
            • @@ -384,129 +393,129 @@

              6.5 Antes de empezar…✏️

            Creamos un ejemplo para ver que funcione:

            -
            serie_numeros <- c(1, 2, 2, 2, 2, 3, 3, 4, 4, 4)
            -resultado <- getmode(serie_numeros)
            -print(resultado)
            +
            serie_numeros <- c(1, 2, 2, 2, 2, 3, 3, 4, 4, 4)
            +resultado <- getmode(serie_numeros)
            +print(resultado)
            ## [1] 2

            Bien ahora si podemos podemos empezar a usar el paquete de roxygen para documentar nuestra función.. comencemos.

            6.6 Generacion de un bloque de documentacion con ayuda del paquete roxygen.

            Podemos insertar un esqueleto de comentarios de roxygen para ver su síntesis. Colocamos el cursor en algún lugar de la definición de nuestra función y buscamos en la pestaña Código > Insertar Roxygen Skeleton.

            -
            #' Title
            -#'
            -#' @param serievector 
            -#'
            -#' @return
            -#' @export
            -#'
            -#' @examples
            -
            -getmode <- function(serievector) {
            -  uniqv <- unique(serievector)
            -  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            -}
            +
            #' Title
            +#'
            +#' @param serievector 
            +#'
            +#' @return
            +#' @export
            +#'
            +#' @examples
            +
            +getmode <- function(serievector) {
            +  uniqv <- unique(serievector)
            +  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            +}

            Ahora ya tenemos un esqueleto de la documentación que nos da una ventaja para su creación. Las líneas de comentarios de Roxygen siempre comienzan con #', el habitual para un comentario # mas un '

            Veamos los comentarios de uno por uno:

            Empezamos con el titulo. Se sugiere poner en el titulo las acciones principales que realiza la función en este caso por ejemplo podremos usar:

            -
            #' @title Encontrar la Moda de una Serie de Números
            -#'
            -#' @param serievector 
            -#'
            -#' @return
            -#' @export
            -#'
            -#' @examples
            -
            -getmode <- function(serievector) {
            -  uniqv <- unique(serievector)
            -  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            -}
            +
            #' @title Encontrar la Moda de una Serie de Números
            +#'
            +#' @param serievector 
            +#'
            +#' @return
            +#' @export
            +#'
            +#' @examples
            +
            +getmode <- function(serievector) {
            +  uniqv <- unique(serievector)
            +  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            +}

            Muy bien!. El siguiente comentario que podemos ver es @param. Pero antes, vamos a añadir una pequeña descripción de la función y como usarla. Primero añadimos la pequeña descripción con @description:

            -
            #' @title Encontrar la Moda de una Serie de Números
            -#'
            -#' @description Esta función lee una serie de números en forma de vector y
            -#' encuentra el elemento que mas se repite, es decir la moda.
            -#' @param serievector
            -#'
            -#' @return
            -#' @export
            -#'
            -#' @examples
            -
            -getmode <- function(serievector) {
            -  uniqv <- unique(serievector)
            -  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            -}
            +
            #' @title Encontrar la Moda de una Serie de Números
            +#'
            +#' @description Esta función lee una serie de números en forma de vector y
            +#' encuentra el elemento que mas se repite, es decir la moda.
            +#' @param serievector
            +#'
            +#' @return
            +#' @export
            +#'
            +#' @examples
            +
            +getmode <- function(serievector) {
            +  uniqv <- unique(serievector)
            +  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            +}

            Ahora vamos a añadir el comentario @usage que nos indica como puedes mandar a llamar la función.

            -
            #' @title Encontrar la Moda de una Serie de Números
            -#'
            -#' @description Esta función lee una serie de números en forma de vector y
            -#' encuentra el elemento que mas se repite, es decir la moda.
            -#' @usage getmode(serievector)
            -#' @param serievector
            -#'
            -#' @return
            -#' @export
            -#'
            -#' @examples
            -
            -getmode <- function(serievector) {
            -  uniqv <- unique(serievector)
            -  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            -}
            +
            #' @title Encontrar la Moda de una Serie de Números
            +#'
            +#' @description Esta función lee una serie de números en forma de vector y
            +#' encuentra el elemento que mas se repite, es decir la moda.
            +#' @usage getmode(serievector)
            +#' @param serievector
            +#'
            +#' @return
            +#' @export
            +#'
            +#' @examples
            +
            +getmode <- function(serievector) {
            +  uniqv <- unique(serievector)
            +  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            +}

            Ahora si vamos a añadir una pequeña descripción de nuestros argumentos. Si tuviéramos mas de un parámetro en nuestra función podríamos llamar las veces que sea necesario el comentario de parámetro con @param, veamoslo.

            Ahora añadimos una pequeña descripción a nuestro único parámetro que es serievector:

            -
            #' @title Encontrar la Moda de una Serie de Números
            -#'
            -#' @description Esta función lee una serie de números en forma de vector y
            -#' encuentra el elemento que mas se repite, es decir la moda.
            -#' 
            -#' @param serievector Es una serie de números en forma de  un vector simple de r.
            -#'
            -#' @return
            -#' @export
            -#'
            -#' @examples
            -
            -getmode <- function(serievector) {
            -  uniqv <- unique(serievector)
            -  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            -}
            +
            #' @title Encontrar la Moda de una Serie de Números
            +#'
            +#' @description Esta función lee una serie de números en forma de vector y
            +#' encuentra el elemento que mas se repite, es decir la moda.
            +#' 
            +#' @param serievector Es una serie de números en forma de  un vector simple de r.
            +#'
            +#' @return
            +#' @export
            +#'
            +#' @examples
            +
            +getmode <- function(serievector) {
            +  uniqv <- unique(serievector)
            +  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            +}

            Después, podemos añadir un comentario de detalles de la función con @details. Por ejemplo, si en nuestro ejemplo tuviéramos ciertos valores no numéricos en nuestro vector de entrada, por ejemplo letras, ¿nuestra función podría leerlas?, o si le diéramos un vector sin caracteres ¿que pasaría?, veamos:

            -
            serie_numeros <- c(0,2,2,"d", "d","d")
            -resultado <- getmode(serie_numeros)
            -print(resultado)
            +
            serie_numeros <- c(0,2,2,"d", "d","d")
            +resultado <- getmode(serie_numeros)
            +print(resultado)
            ## [1] "d"
            -
            serie_numeros <- c()
            -resultado <- getmode(serie_numeros)
            -print(resultado)
            +
            serie_numeros <- c()
            +resultado <- getmode(serie_numeros)
            +print(resultado)
            ## NULL

            Entonces, esto es un ejemplo de lo que podríamos poner en el comentario @details. Hagamoslo describiendo esto. En details podemos agregar detalles un poco mas específicos que en la descripción de la función

            -
            #' @title Encontrar la Moda de una Serie de Números
            -#'
            -#' @description Esta función lee una serie de números en forma de vector y
            -#' encuentra el elemento que mas se repite, es decir la moda.
            -#' 
            -#' @param serievector Es una serie de números en forma de  un vector simple de r.
            -#'
            -#' @details si tu vector de entrada puede ser interpretado alternando números y 
            -#' letras escritas entre comillas "". Si un vector esta vacío, dará como 
            -#' resultado un NULL.
            -#' @return
            -#' @export
            -#'
            -#' @examples
            -
            -getmode <- function(serievector) {
            -  uniqv <- unique(serievector)
            -  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            -}
            +
            #' @title Encontrar la Moda de una Serie de Números
            +#'
            +#' @description Esta función lee una serie de números en forma de vector y
            +#' encuentra el elemento que mas se repite, es decir la moda.
            +#' 
            +#' @param serievector Es una serie de números en forma de  un vector simple de r.
            +#'
            +#' @details si tu vector de entrada puede ser interpretado alternando números y 
            +#' letras escritas entre comillas "". Si un vector esta vacío, dará como 
            +#' resultado un NULL.
            +#' @return
            +#' @export
            +#'
            +#' @examples
            +
            +getmode <- function(serievector) {
            +  uniqv <- unique(serievector)
            +  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            +}

            Ya casi terminamos de llenar nuestra documentación, pero antes vamos a ver algunos otros arrobas que pudieran ser importantes. El @import e @importfrom importan funciones de otros paquetes en caso @@ -517,27 +526,27 @@

            6.6 Generacion de un bloque de do ejemplo necesita leer un archivo .tsv con la función read_tsv del paquete readr y después reconvertir la tabla resultante en un archivo con write.table pero solo necesitas esa función del paquete utils, entonces haríamos:

            -
            #' @title Encontrar la Moda de una Serie de Números
            -#'
            -#' @description Esta función lee una serie de números en forma de vector y
            -#' encuentra el elemento que mas se repite, es decir la moda.
            -#' 
            -#' @param serievector Es una serie de números en forma de  un vector simple de r.
            -#'
            -#' @details si tu vector de entrada puede ser interpretado alternando números y 
            -#' letras escritas entre comillas "". Si un vector esta vacío, dará como 
            -#' resultado un NULL.
            -#' @import readr
            -#' @importFrom utils write.table
            -#' @return
            -#' @export
            -#'
            -#' @examples
            -
            -getmode <- function(serievector) {
            -  uniqv <- unique(serievector)
            -  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            -}
            +
            #' @title Encontrar la Moda de una Serie de Números
            +#'
            +#' @description Esta función lee una serie de números en forma de vector y
            +#' encuentra el elemento que mas se repite, es decir la moda.
            +#' 
            +#' @param serievector Es una serie de números en forma de  un vector simple de r.
            +#'
            +#' @details si tu vector de entrada puede ser interpretado alternando números y 
            +#' letras escritas entre comillas "". Si un vector esta vacío, dará como 
            +#' resultado un NULL.
            +#' @import readr
            +#' @importFrom utils write.table
            +#' @return
            +#' @export
            +#'
            +#' @examples
            +
            +getmode <- function(serievector) {
            +  uniqv <- unique(serievector)
            +  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            +}

            Así podemos importar las funciones que necesitemos de otros paquetes y se incluirán en la documentación y se cargaran automáticamente al cargar tu paquete.

            :eyes::exclamation: Para un correcto funcionamiento de tu paquete y al estar los @@ -548,52 +557,52 @@

            6.6 Generacion de un bloque de do ser un archivo, una tabla, un numero,etc. Entonces retomando la función que usamos al inicio, vamos a escribir una descripción corta del resultado de la función getmode().

            -
            #' @title Encontrar la Moda de una Serie de Números
            -#'
            -#' @description Esta función lee una serie de números en forma de vector y
            -#' encuentra el elemento que mas se repite, es decir la moda.
            -#' 
            -#' @param serievector Es una serie de números en forma de  un vector simple de r.
            -#'
            -#' @details si tu vector de entrada puede ser interpretado alternando números y 
            -#' letras escritas entre comillas "". Si un vector esta vacío, dará como 
            -#' resultado un NULL.
            -#' @return El carácter con mas frecuencia de el vector de entrada.
            -#' @export
            -#'
            -#' @examples
            -
            -getmode <- function(serievector) {
            -  uniqv <- unique(serievector)
            -  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            -}
            +
            #' @title Encontrar la Moda de una Serie de Números
            +#'
            +#' @description Esta función lee una serie de números en forma de vector y
            +#' encuentra el elemento que mas se repite, es decir la moda.
            +#' 
            +#' @param serievector Es una serie de números en forma de  un vector simple de r.
            +#'
            +#' @details si tu vector de entrada puede ser interpretado alternando números y 
            +#' letras escritas entre comillas "". Si un vector esta vacío, dará como 
            +#' resultado un NULL.
            +#' @return El carácter con mas frecuencia de el vector de entrada.
            +#' @export
            +#'
            +#' @examples
            +
            +getmode <- function(serievector) {
            +  uniqv <- unique(serievector)
            +  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            +}

            Por ultimo tenemos @export que es el encargado de renderizar la documentación para que pueda aparecer en la ventana de Ayuda (abajo a la derecha). esta opción la dejamos para funciones principales que el usuario va a utilizar, aunque puede que existan alguna funciones internas que no queremos que el usuario vea. En ese caso vamos a usar @noRd en lugar de este.

            Antes de terminar podemos incluir ejemplos de como funciona nuestra función para un mejor entendimiento, pongamos los que ya realizamos:

            -
            #' @title Encontrar la Moda de una Serie de Números
            -#'
            -#' @description Esta función lee una serie de números en forma de vector y
            -#' encuentra el elemento que mas se repite, es decir la moda.
            -#' 
            -#' @param serievector Es una serie de números en forma de  un vector simple de r.
            -#'
            -#' @details si tu vector de entrada puede ser interpretado alternando números y 
            -#' letras escritas entre comillas "". Si un vector esta vacío, dará como 
            -#' resultado un NULL.
            -#' @return El carácter con mas frecuencia de el vector de entrada.
            -#' @export
            -#'
            -#' @examples
            -#' serie_números <- c(1, 2, 2, 2, 2, 3, 3, 4, 4, 4)
            -#' resultado <- getmode(serie_números)
            -#' print(resultado)
            -
            -getmode <- function(serievector) {
            -  uniqv <- unique(serievector)
            -  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            -}
            +
            #' @title Encontrar la Moda de una Serie de Números
            +#'
            +#' @description Esta función lee una serie de números en forma de vector y
            +#' encuentra el elemento que mas se repite, es decir la moda.
            +#' 
            +#' @param serievector Es una serie de números en forma de  un vector simple de r.
            +#'
            +#' @details si tu vector de entrada puede ser interpretado alternando números y 
            +#' letras escritas entre comillas "". Si un vector esta vacío, dará como 
            +#' resultado un NULL.
            +#' @return El carácter con mas frecuencia de el vector de entrada.
            +#' @export
            +#'
            +#' @examples
            +#' serie_números <- c(1, 2, 2, 2, 2, 3, 3, 4, 4, 4)
            +#' resultado <- getmode(serie_números)
            +#' print(resultado)
            +
            +getmode <- function(serievector) {
            +  uniqv <- unique(serievector)
            +  uniqv[which.max(tabulate(match(serievector, uniqv)))]
            +}

            Ahora si, una vez teniendo listo el bloque de comentarios para la documentación, vamos a ejecutar devtools::load_all() para cargar nuestras funciones y hecho esto, ejecutamos devtools::document() o presionamos Ctrl/Cmd + Shift + D para convertir los comentarios en archivo .Rd y poder renderizarlo.

            💯 Listo, tenemos nuestra documentación para una función. Así se verá cuando el paquete esté terminado.

            diff --git a/docs/index.html b/docs/index.html index 95bf960..e2d56f9 100644 --- a/docs/index.html +++ b/docs/index.html @@ -217,6 +217,15 @@
          • 5 Creando mis primeras funciones
          • 6 Documentación de funciones
              diff --git a/docs/proyectos-colaborativos-1.html b/docs/proyectos-colaborativos-1.html index eb0e6d6..7e262b3 100644 --- a/docs/proyectos-colaborativos-1.html +++ b/docs/proyectos-colaborativos-1.html @@ -217,6 +217,15 @@
            • 5 Creando mis primeras funciones
            • 6 Documentación de funciones
                diff --git a/docs/reference-keys.txt b/docs/reference-keys.txt index ec4c7d9..7a4e30a 100644 --- a/docs/reference-keys.txt +++ b/docs/reference-keys.txt @@ -52,6 +52,15 @@ modificando-el-archivo-description modificando-el-archivo-news creando-mis-primeras-funciones diapositivas-4 +nombre-de-la-función +estructura-de-la-función +tu-turno +argumentos +tu-turno-1 +indentación +uso-de-espacios +comentarios +mensajes-para-el-usuario documentación-de-funciones diapositivas-5 links-importantes diff --git a/docs/search_index.json b/docs/search_index.json index 4668e3d..d0e2d9d 100644 --- a/docs/search_index.json +++ b/docs/search_index.json @@ -1 +1 @@ -[["index.html", "Desarrollo de paqueterías de R/Bioconductor. Bienvenida 0.1 Instructores 0.2 Ayudantes 0.3 Temario 0.4 Patrocinadores 0.5 Licencia", " Desarrollo de paqueterías de R/Bioconductor. Dra. Joselyn Cristina Chávez-Fuentes, Dra. Mirna Vázquez Rosas-Landa, M.C. Erick Cuevas-Fernández, Dra. Alejandra Medina-Rivera, Bienvenida Les damos la bienvenida al Workshop Desarrollo de paqueterías de R/Bioconductor! En este taller aprenderás cuáles son los pasos cruciales para desarrollar un paquete de R y algunas buenas prácticas para la generación de código. Con la integración de estas herramientas, tendrás la oportunidad de crear tu primer paquete y contribuir a la comunidad de desarrolladores. Adicionalmente, aprenderás a crear un sitio web para mostrar el funcionamiento de un paquete de R. 0.1 Instructores Dra. Joselyn Cristina Chávez Fuentes: Estancia Postdoctoral en Icahn School of Medicine at Mount Sinai. Dra. Mirna Vázquez Rosas Landa: Investigadora en el Instituto de Ciencias de Mar y Limnología de la UNAM. Dra. Alejandra Medina Rivera: Investigadora Asociada en el Laboratorio Internacional de Investigación de Medicina Genómica, UNAM. M.C. Erick Cuevas Fernández: Estudiante de Doctorado en la Universidad Nacional Autónoma de México. M.C. José Antonio Ovando Ricárdez: Estudiante de Doctorado en el Instituto Nacional de Enfermedades Respiratorias Ismael Cosío Villegas. 0.2 Ayudantes Dra. Evelia Coss: Posdoctoral en el Laboratorio Internacional de Investigación de Medicina Genómica, UNAM. M.C. José Antonio Ovando Ricárdez: Estudiante de Doctorado en el Instituto Nacional de Enfermedades Respiratorias Ismael Cosío Villegas. 0.3 Temario Consulta el calendario de este curso en: https://bit.ly/calendarcdsb2024 Día 1: Flujo de trabajo orientado a proyectos: Introducción al trabajo con proyectos de RStudio. Paths seguros. Control de versiones con GitHub y RStudio. Solución de problemas con las versiones de paquetes de Rstudio. Día 2: Creación de paquetes de R/Bioconductor Parte I Infraestructura de un paquete de R/Bioconductor. Documentación de funciones. Sesión social: Conociendo a la comunidad. Proyectos colaborativos Parte I. Día 3: Creación de paquetes de R/Bioconductor Parte II Diseño de pruebas. Creación de viñetas. Compilación e instalación de paquetes. Proyectos colaborativos Parte II. Día 4: Creación de sitios web para la documentación de paquetes de R Creación de sitios web con pkgdown Proyectos colaborativos Parte III. Presentación de proyectos. Clausura. 0.4 Patrocinadores Agradecemos a nuestros patrocinadores: 0.5 Licencia Este material posee una licencia tipo Creative Commons Attribution-ShareAlike 4.0 International License. Para conocer más sobre esta licencia, visite http://creativecommons.org/licenses/by-sa/4.0/ "],["trabajando-con-proyectos-de-rstudio.html", "1 Trabajando con proyectos de RStudio 1.1 Diapositivas 1.2 ¿Qué es un proyecto de RStudio? 1.3 ¿Cómo generamos un proyecto de RStudio? 1.4 ¿Por qué usar proyectos de RStudio? 1.5 Algunos hacks! 1.6 Generando rutas seguras", " 1 Trabajando con proyectos de RStudio Joselyn Cristina Chávez Fuentes 28 de octubre de 2024 1.1 Diapositivas div.grey { background-color: #bfbfbf; } div.center { text-align:center; } 1.2 ¿Qué es un proyecto de RStudio? Es un archivo especial de R, compatible con RStudio, que al ejecutarlo hará 3 cosas: Abrirá una nueva sesión de RStudio. Establecerá la ubicación del proyecto como tu directorio de trabajo. Establecerá la ubicación del proyecto como la raíz de los archivos. 1.3 ¿Cómo generamos un proyecto de RStudio? 1.3.1 Opción 1: Creando un proyecto en un directorio nuevo. En las opciones de RStudio Ve a File > New project > New Directory > New Project. Asigna un nombre a tu proyecto, sin espacios y sin caracteres especiales. Selecciona la ubicación donde crearás el nuevo directorio. Selecciona la opción Open in New Session. Oprime Create Project. 1.3.2 Opción 2: Creando un proyecto en un directorio existente. Crea un directorio en alguna ubicación conocida de tu computadora. Asigna un nombre a tu directorio, sin espacios y sin caracteres especiales (Este será el nombre de tu proyecto). En las opciones de RStudio ve a File > New project > Existing Directory. Selecciona la ubicación donde previamente creaste el directorio. Selecciona la opción Open in New Session. Oprime Create Project. 1.4 ¿Por qué usar proyectos de RStudio? Te permiten ser más organizado y pasar de tener una ensalada de archivos a tener carpetas para cada sección del análisis. Compartamentalizas tu trabajo al generar un proyecto específico para cada análisis. Te permiten trabajar con varios proyectos a la vez en sesiones independientes de RStudio, cada uno con sus propias variables, directorio de trabajo y archivos. Establece automáticamente tu directorio de trabajo. En lugar de usar setwd() solamente requieres ejecutar el archivo .Rproj para abrir la sesión y trabajar en la ubicación del proyecto. Puedes usar rutas relativas (y estables) a tus archivos, que seguirán funcionando sin importar en dónde se ubique tu proyecto. Facilita el compartir y reproducir tu trabajo. No más rutas al estilo ~/MiComputadora/MiFolder/MiArchivo. Comparte la carpeta completa de tu proyecto con todos los archivos necesarios y usa rutas relativas dentro del Rscript, por ejemplo ./datos. Nos ayuda a establecer colaboraciones y trabajar con plataformas de control de versiones. Actividad Comprueba algunas ventajas de usar proyectos de RStudio. Genera un nuevo proyecto de RStudio llamado ‘miproyecto’, recuerda que existen varias formas para hacerlo. Cierra la sesión y vuelve a abrirla ejecutando desde la terminal open miproyecto.Rproj o dando doble click sobre el archivo miproyecto.Rproj. Evalúa tu directorio de trabajo ejecutando en la consola de RStudio el comando getwd(). Cierra la sesión y mueve toda la carpeta de tu proyecto a otra ubicación. Si lo creaste en Documentos mueve la carpeta al Escritorio o viceversa. Abre nuevamente el proyecto y verifica el directorio de trabajo, ¿Cambió el directorio de trabajo? Sin cerrar este proyecto, abre alguno de los proyectos que generaste previamente (por ejemplo directorioprevio.Rproj), recuerda que puedes seleccionar Open Project in New session 1.5 Algunos hacks! RStudio recuerda los proyectos con los que has trabajado recientemente. Ve a la esquina superior derecha y da click en la flecha junto al nombre de tu proyecto actual. Verás todos los proyectos recientes. Si das click en el nombre de alguno de ellos te abrirá el proyecto en la misma sesión, si das click en el recuadro con flecha blanca te abrirá una nueva sesión con tu proyecto. Crea todos tus proyectos dentro de una carpeta principal y usa el buscador de archivos para acceder a ellos rápidamente. 1.6 Generando rutas seguras Se construyen a partir de una base estable El directorio de trabajo cambia de usuario a usuario y dependiendo de la ubicación de los archivos. getwd() Deben funcionar en cualquier sistema operativo Una ruta en sistemas Linux se ve así: "/Users/joselynchavez/Documents/materiales_cdsb2024" Mientras que una ruta en Windows se ve así: "C:\\Documents/materiales_cdsb2024" 1.6.1 El paquete here Usemos el paquete here para detectar la ubicación del proyecto: here::here() Ahora generemos una ruta segura a partir de la raíz del proyecto here::here("mi_tabla.csv") here::here("subfolder", "mi_tabla.csv") 1.6.2 Usando el paquete fs Por defecto, usa el directorio de trabajo actual como base y detecta el sistema operativo automáticamente. fs::path("mi_tabla.csv") fs::path("subfolder", "mi_tabla.csv") Tiene como ventaja que puede construir las rutas a partir del home del usuario. fs::path_home() fs::path_home("mi_tabla.csv") 1.6.3 Usando funciones base Si no deseas incluir el paquete ‘here’ en las dependencias de tu paquete, puedes usar la función file.path Esta función usa como base el directorio de trabajo actual y detecta el sistema operativo para construir la ruta. file.path("mi_tabla.csv") file.path("subfolder", "mi_tabla.csv") "],["control-de-versiones-con-github-y-rstudio.html", "2 Control de versiones con GitHub y RStudio 2.1 Diapositivas 2.2 ¿Por qué hacer control de versiones de nuestros proyectos? 2.3 Git 2.4 Recomendaciones para sus proyectos 2.5 Proyectos colaborativos 2.6 GitHub 2.7 Manual de sobreviviencia con Git Y GitHub en RStudio (en caso de ser necesario) 2.8 Cómo clonar un repositorio y tener conección/permisos para modificarlo? 2.9 Credenciales HTTPS en Cache 2.10 Conectando RStudio con Git y Github. 2.11 GitHub primero, RStudio después… 2.12 Rmarkdown en GitHub 2.13 RStudio primero y GitHub también 2.14 Proyecto existente, GitHub al final 2.15 Git basics: commands 2.16 Merge conflics 2.17 Merge conflics 2.18 En resumen", " 2 Control de versiones con GitHub y RStudio Dra. Alejandra Medina Rivera 28 de octubre de 2024 div.color { border-radius: 5px; padding: 20px; margin: 30px 0px 30px;} div.red { background-color:#f67155; } div.orange{ background-color:#f0BB51;} div.pair { display: flex; flex-direction: row; justify-content: center; text-align:center; padding:0px} div.inside { width: 49%; padding: 0px} div.scroll { max-height: 400px; overflow-y: auto; background: #111111; border-radius:5px; padding: 10px; margin: 30px 0px 30px; color: #999999;} div.alert{color:#bd475d; background-color:transparent} Este documento se basa en “Happy Git with R” de Jenny Bryan, los STAT 545 TAs, Jim Hester https://happygitwithr.com 2.1 Diapositivas 2.2 ¿Por qué hacer control de versiones de nuestros proyectos? ✅ Los proyectos suelen cambiar y crecer. 💾 Es díficil saber cuáles fueron todos los cambios a lo largo del tiempo (en especial tiempos largos, hazlo por tu yo del futuro!). 🤔 Las colaboraciones se pueden complicar sin un buen control de versiones. 🔐 Seguridad. 2.3 Git Git es un sistema de control de versiones Git funciona con GitHub, Bitbucket o GitLab ¿Por qué usar Git en vez de solo renombrar los archivos? ✅✅Por qué es mejor tener una filogenia del archivo. Git es un sistema de control de versiones distribuido, gratuito y de código abierto, diseñado para manejar todo tipo de proyectos, desde los más pequeños hasta los más grandes, con rapidez y eficiencia. Git es fácil de aprender y ocupa poco espacio con un rendimiento rapidísimo. Supera a las herramientas SCM como Subversion, CVS, Perforce y ClearCase con características como la ramificación local barata, las cómodas áreas de preparación y los múltiples flujos de trabajo. 2.3.1 Git vs controles de versión a mano Con Git cada contribuidor tiene una copia del repositorio central, con todos los archivos y la historia de los cambios por los que han pasado. Excuse me, do you have a moment to talk about version control?, Jennifer Bryan, 2017 ⚠️ NO OLVIDES TENER INSTALADO Git, en caso de que aún no lo hayas instalado, lo puedes descargar en el siguiente enlace https://git-scm.com/downloads. Para conocer la localización y la versión de Git que tienes en tu computadora, corre el siguiente comando en la terminal: which git y git --version 2.4 Recomendaciones para sus proyectos Dedicar un directorio Es mejor organizarlo en un RStudio Project Hacer un repositorio de Git Trabajen como siempre, solo además de guardar, recuerden hacer commit De vez en vez hagan push de sus cambios cuando los hayan verificado. 2.5 Proyectos colaborativos GitHub se parece más a un GoogleDoc que a un Word Document. Es fácil que los colaboradores hagan cambios y también es fácil saber quién hizo que. El owner del proyecto puede dar permisos a los diferentes colaboradores. También existen organizaciones, esto puede ser útil para manejar los permisos de grupos grandes de colaboración. 2.6 GitHub GitHub es una plataforma para guardar proyectos, hace uso de Git. Su principal utilidad es para generar código fuente de programas. ⚠️ NO OLVIDES TENER UNA CUENTA EN GITHUB, en caso de que aún no lo hayas hecho, puedes ir la página de GitHub y seleccionar join. Es indispensable tu usuario para los ejercicios que siguen. También existen otras plataformas como Bitbucked y GitLab, las cuales funcionan de manera similar a GitHub. 2.7 Manual de sobreviviencia con Git Y GitHub en RStudio (en caso de ser necesario) Por cualquier problema con la conexión entre RStudio y Git, siempre ten en cuenta la ubicación de dónde se instaló Git. Puedes usar en la terminal which git (Mac y Linux) O bien usar en la terminal where git (Windows) Recuerda que la terminal (o línea de comandos ó consola ó shell ó bash) es un programa en tu computadora que funciona para correr otros programas. Desde RStudio puedes abrir la terminal, lo cual es muy conveniente si estás trabajando en un proyecto. Puedes abrir una terminal con: Tools > Terminal (abre la terminal dentro del IDE de RStudio) Tools > Shell (abre una terminal externa a RStudio) 2.8 Cómo clonar un repositorio y tener conección/permisos para modificarlo? Git puede comunicarse con un servidor remoto usando uno de dos protocolos, HTTPS o SSH, y cada protocolo usa credenciales diferentes. La recomendación actual de GitHub es usar HTTPS porque es la manera más fácil de configurar y tiene operabilidad en multiples redes y plataformas. Es menos probable que HTTPS sea bloqueado por un firewall. Una conexión HTTPS permite que credential.helper almacene en caché su contraseña. (por tanto puedes configurar tu usuario y contraseña en tu equipo de uso) Es más sencillo acceder a un repositorio desde cualquier lugar, ya que solo necesitas los detalles de tu cuenta (no se requieren claves SSH) para escribir en el repositorio. Usualmente cuando inicies un proyecto colaborativo con GitHub inicializa el ropositorio con un README. Copia el HTTPS URL para clonar el repositorio en la terminal git clone https://github.com/TU-USUARIO/TU-REPOSITORIO.git. 2.9 Credenciales HTTPS en Cache Para usar HTTPS debes crear un token de acceso personal, PAT (PERSONAL ACCESS TOKEN), esa será tu credencial para HTTPS. Es una alternativa al uso de contraseñas para la autenticación en GitHub. Como precaución de seguridad, GitHub elimina automáticamente los tokens de acceso personales que no se han usado durante un año. ¿Cómo crear un token? Ve a tu perfil de GitHub, dale click a la imagen de perfil (usualmente en la esquina superior derecha), y busca la opción de settings ó configuración según sea la configuración de idioma que tengas. Da click a continuación en Developer settings ó Parámetros del desarrollador. En la barra lateral izquierda da click en Tokens de acceso personal. Haz click en Generar un nuevo token. Asígna un nombre descriptivo a tu token. Selecciona los alcances o permisos que deseas otorgarle a este token. Para usar tu token para acceder a repositorios desde la línea de comando, selecciona repo. (Recomendados: repo, user, workflow ) Finalmente haz click en generar token. Listo, copia y pega tu token en el lugar dónde siempre lo puedas volver a copiar, ya que por razones de seguridad, una vez salgas de la página no podrás volver a ver el token. Nota: Preserva tus tokens de la misma manera que tus contraseñas y no se las reveles a nadie. Una vez que tengas un token, puedes ingresarlo en lugar de tu contraseña cuando realices operaciones de Git a través de HTTPS. El punto final es que una vez configurada una PAT, varios paquetes de R, incluidos usethis y gh, podrán trabajar con la API de GitHub en su nombre, de forma automática. Por lo tanto, una PAT configurada correctamente significa que todo esto funcionará a la perfección: - Operaciones HTTPS remotas a través de la línea de comando Git y, por lo tanto, a través de RStudio - Operaciones HTTPS remotas a través del paquete gert R y, por lo tanto, usethis - Operaciones de la API de GitHub a través del paquete gh R y, por lo tanto, usethis Probar el repositorio Clonado Después de hacer clone Usa estos comandos para verificar tu repositorio y revisar desde dónde se está sincorinzando. cd myrepo ls -la head README.md git remote show origin Probemos haciendo un cambio en el README echo "Something I want to add to the README in my local computer" >> README.md git status Qué pasó? Ahora tenemos que decirle a git que queremos seguir los cambios de ese archivo Vamos a commit los cambios y luego a subir (push) los mismos a GitHub git add README.md git commit -m "A commit from my local computer" git push Recuerda tu TOKEN!! ¿Cómo crear un token desde R? Puedes ir directamente a la página de GitHub a la parte para generar tu token de acceso personal mediante la siguiente función: usethis::create_github_token() Y con las opciones que se mencionaban anteriormente puedes configurar y crear tu PAT. Si lo que quieres es especificar tu PAT en RStudio, las siguientes funciones te serán útiles: library(gitcreds) gitcreds_set() library(credentials) set_github_pat() Para eliminar credenciales utiliza la función credentials::git_credential_forget() 2.9.1 Actividad Ejecuta los códigos y genera tu PAT, recuerda no perderlo! 2.10 Conectando RStudio con Git y Github. Para lo que sigue a continuación, deberías tener esto: Tener una cuenta en GitHub R y RStudio actualizados Git instalado Saber que desde la terminal puedes hacer push y pull 2.11 GitHub primero, RStudio después… Crea un repositorio en GitHub: mi_repositorio > Public > YES initialize this repository with a README > clicken el gran botón verde “Create repository” En RStudio crea un nuevo proyecto: File > New Project > Version Control > Git. Ahi pega el URL del repositorio https://github.com/mi_usuario/mi_repositorio.git. Da click en Create Project. Esto nos generará los siguientes elementos: Un directorio nuevo Un repositorio Git enlazado a al repositorio de GitHub Un proyecto en RStudio Con este procedimiento ya no es necesario preocuparse por configurar controles remotos Git y rastrear ramas en la línea de comandos. 2.11.1 Actividad Genera un repositorio con el nombre que desees. Y conéctalo a RStudio. Cerciorate de que el archivo README se encuentre en tu nueva carpeta. Usa la función usethis::use_r(\"titulo_de_un_script\") y observa lo que sucede. PAUSA ¿Cómo comento y doy push/pull desde RStudio? 2.11.2 Comentar, pull y push Con la flecha azul podemos hacer pull (RECUERDA HACERLO ANTES DE HACER UN PUSH), y con la flecha verde un push. Para poder comentar y hacer push debemos marcar con una flechita mediante un click en las pequeñas cajas blancas de la columna Staged, damoc click en commit lo cual no abre la siguiente ventana. Volvemos a dar click en commit, y finalizamos con push (flecha verde). 2.12 Rmarkdown en GitHub Creemos un Rmakrdown y subámoslo a GitHub Ahora hay que agregarlo al repositorio (add), stage and commit. Subieron el hmlt? Qué tal se ve? No se ve como queremos, verdad? Para eso necesitamos recuperar el .md. El .md es un resultado intermedio de crear el html desde Rmd. Tenemos que cambiar el header para esto --- title: "RmarkwondTest" output: html_document: keep_md: true --- 2.12.1 Actividad Usa el código dir.create(\"mis_imagenes\") en la consola de tu sesión de RStudio (la que está vinculada a tu repositorio). Ejecuta el siguiente código quitando los #: install.packages("MASS") library (MASS) data(MASS::cats) # pdf("mis_imagenes/cats_plot.pdf") ggplot(cats, aes(x = Sex)) + geom_bar(fill = "orange", color = "black") + theme_classic() + xlab("Sexo") + ylab("Número de Gatos") + ggtitle("Gatos") # dev.off() Comenta y da push a los cambios que realizaste en el repositorio. 2.13 RStudio primero y GitHub también Usa uno de los proyectos que hayas generado en las sesiones anteriores, PERO, que no esté enlazado a GitHub. Ahora veremos como conectar un proyecto de R existente con GitHub. Realiza los pasos que hicimos en GitHub primero, RStudio después pero asegurate de crear un repositorio con un nuevo nombre. Y LISTO!! usa un simple ctrl + c, ó mv ó click derecho + copiar ó el método que prefieras para mover o copiar archivos. Copia los archivos de tu antigüo proyecto al proyecto nuevo. Solo haz commit y push y listo, lo que tenía en tu antigüo proyecto ya está enlazado a GitHub. 2.14 Proyecto existente, GitHub al final Supongamos que tenemos un proyecto de R existente en algún lugar de nuestra computadora. NOTA: Para generar proyecto de RStudio desde la consola puedes utilizar el siguiente código: usethis::create_project() O en RStudio con File > New Project > Existing Directory Si su proyecto ya es un proyecto de RStudio, ejecútelo. ¿Ya es un repositorio de Git? La presencia del panel de Git debería alertarlo. Si es así, ha terminado. Sino este es el primer camino a seguir: Con el páquete usethis usa la función usethis::use_git En RStudio ve a Tools > Project Options > Git/SVN. Dentro de Version control system, selecciona Git. Y da click a “Yes” cuando aparezca “Confirm New Git Repository?”. Si usaste RStudio o usethis, el proyecto debería reiniciarse en RStudio. Hazlo tu mismo si hizo git init. RStudio ahora debería tener un panel Git. 2.14.1 Breviario cultural con los PATs Si usas el paquete usethis Y has configurado un token de acceso personal (PAT) de GitHub has esto en R: usethis::use_github() Esto creará un nuevo repositorio en GitHub, lo agregará como un control remoto, configurará una rama de seguimiento y lo abrirá en su navegador. Lea la ayuda de use_github() para conocer sus argumentos y consejos sobre cómo configurar una PAT. Esto es extremadamente útil para una variedad de flujos de trabajo que llaman a la API de GitHub. Considere configurar esto si usa usethis, devtools o gh con regularidad. Volviendo al tema de Proyecto existente, GitHub al final. Otra opción que se puede hacer para conectar un proyecto existen a GitHub es ir a hacer un repositorio a GitHub PERO ten en cuenta los siguientes cambios: Elije un nombre de repositorio; probablemente debería coincidir con el nombre de su proyecto y directorio local. NO inicialice este repositorio con un archivo README. Todo lo demás es igual a los pasos que hacíamos en GitHub primero, RStudio después… Ahora ve a tu proyecto de RStudio, has clic en los “dos cuadros de color púrpura y un cuadrado blanco” en el panel de Git. Has clic en “Agregar control remoto”. Pegue la URL aquí y elija un nombre remoto, casi con certeza el origin. Ahora “ADD”. Pasado esto deberiamos volver en el cuadro de diálogo “New Branch”. Ingresa “master” como el nombre de la rama y asegúrate de que la opción “Sync branch with remote” esté marcada. Haz clic en “Create”. En el siguiente cuadro de diálogo elije “overwrite”. Ahora solo haz commit/pull/push y cérciorate que FUNCIONE!! 2.15 Git basics: commands Fetch Commits git fetch Create and Switch to a branch git branch [branch-name] git checkout [branch-name] 2.16 Merge conflics A veces, no tan a veces también, las cosas no salen bien a la primera Merging (Fusionar) es una de esas cosas Cuando bajamos un cambio o fusionamos branches esto puede pasar. Primera regla: NO ENTRAR EN PANICO!!! Revisen el status del repositorio. Qué archivo tiene conflicto? 2.17 Merge conflics Abran ese archivo y busquen los problemas de merge. Es fácil, se ven así: <<<<<<< HEAD:index.html <div id="footer">contact : email.support@github.com</div> ======= <div id="footer"> please contact us at support@github.com </div> >>>>>>> issue-5:index.html Editen esa sección, dejen una versión final. Hagan commit y push Si entran en pánico? Aborten la misión! git merge --abort t 2.18 En resumen ¡QUE LA FUERZA TE ACOMPAÑE! "],["solución-de-problemas-con-las-versiones-de-paquetes-de-rstudio.html", "3 Solución de problemas con las versiones de paquetes de Rstudio 3.1 Diapositivas", " 3 Solución de problemas con las versiones de paquetes de Rstudio Yalbi Balderas 28 de octubre de 2024 3.1 Diapositivas "],["creando-la-infraestructura-de-un-paquete.html", "4 Creando la infraestructura de un paquete 4.1 Diapositivas 4.2 Los primeros pasos 4.3 Checks 4.4 Modificando el archivo DESCRIPTION 4.5 Modificando el archivo NEWS", " 4 Creando la infraestructura de un paquete Joselyn Cristina Chávez Fuentes 29 de octubre de 2024 4.1 Diapositivas 4.2 Los primeros pasos Revisar si podemos usar el nombre del paquete available::available("mipaquete") Crear la estructura inicial del paquete usethis::create_package("mipaquete") Podemos agregar la estructura de biocthis biocthis::use_bioc_pkg_templates() Pedir que Git ignore el archivo .Rproj usethis::use_git_ignore("*.Rproj") Crear el respositorio de GitHub usethis::use_github() Crear el archivo Description estilo Bioconductor biocthis::use_bioc_description() Crear el archivo README estilo Bioconductor biocthis::use_bioc_readme_rmd() devtools::build_readme() Recuerda guardar los cambios, hacer commit y push. Crear el archivo NEWS estilo Bioconductor biocthis::use_bioc_news_md() Crear los archivos de ayuda para usuarios y contribuidores biocthis::use_bioc_coc() usethis::use_tidy_contributing() biocthis::use_bioc_support() biocthis::use_bioc_issue_template() biocthis::use_bioc_citation() 4.3 Checks 4.3.1 BiocCheck BiocManager::install("BiocCheck") BiocCheck::BiocCheck() Algunas reglas de BiocCheck: Utilizar el símbolo <- en lugar de = para definir funciones y variables. Utilizar TRUE y FALSE en lugar de T y F. Indentar el código usando 4 espacios. Las líneas de código y documentación no deben ser mayores a 80 caracteres. Las funciones deben tener 50 líneas de código o menos. El paquete debe contener al menos una viñeta. Al menos 80% de las funciones deben tener ejemplos reproducibles. Las dependencias deben ser declaradas en el archivo DESCRIPTION. El paquete debe tener al menos un biocView. El tamaño del paquete no debe ser mayor 5Mb. El maintainer debe estar suscrito a la lista de correo de Bioconductor. El maintainer debe agregar su paquete en los tags de Bioconductor. 4.3.2 rcmdcheck install.packages("rcmdcheck") rcmdcheck::rcmdcheck() Algunas reglas de rcmdcheck: El paquete debe ser instalable. Los ejemplos de las funciones deben ser reproducibles. Las viñetas deben ser reproducibles. Todas las unidades de prueba deben pasar sin errores. El archivo DESCRIPTON debe tener el formato adecuado. 4.4 Modificando el archivo DESCRIPTION Paquete Este es el nombre del paquete. El nombre del repositorio y el nombre del paquete en la descripción deben coincidir (incluyendo mayúsculas y minúsculas). Título Este es un título breve pero descriptivo para el paquete. Versión Todos los paquetes de Bioconductor utilizan un esquema de versión x.y.z. Cuando se envía por primera vez a Bioconductor, un paquete debe tener la versión 0.99.0. Se aplican las siguientes reglas: x es normalmente 0 para paquetes que aún no han sido liberados. y es par para paquetes liberados, e impar para paquetes en desarrollo. Generalmente, no se debe aumentar este número en el pre-release. z se incrementa siempre que se realizan cambios en el paquete. Descripción La descripción debe ser una visión general relativamente breve pero detallada de lo que implica la funcionalidad del paquete. Debe ser de al menos tres oraciones completas. Autores Se requiere una designación de maintainer (cre) con una dirección de correo electrónico que se mantenga activamente. Esta dirección de correo se utilizará para el contacto con respecto a cualquier problema que surja con el paquete en el futuro. Idealmente, se debe incluir el ORCiD por lo menos del maintainer. person("Lori", "Shepherd", email = Lori.Shepherd@roswellpark.org, role = c("cre", "aut"), comment = c(ORCID = "0000-0002-5910-4010")) Sólo debe figurar una persona como responsable para garantizar un único punto de contacto. Esta persona tendrá acceso al repositorio git en git.bioconductor.org. El acceso a Commit puede ser dado a otros desarrolladores por solicitud en la lista de correo bioc-devel. Otra opción es añadir colaboradores al repositorio de GitHub. Este enfoque permite el desarrollo por muchos pero restringe el acceso a git.bioconductor.org. Licencia El campo de licencia debe referirse preferentemente a una licencia estándar no restrictiva. Las licencias que restringen el uso, por ejemplo, a investigadores académicos o sin fines de lucro, no son adecuadas para Bioconductor. Los paquetes de bioconductor básico suelen estar licenciados bajo Artistic-2.0. El paquete debe contener sólo código que pueda ser redistribuido de acuerdo con la licencia del paquete. LazyData Para paquetes que incluyen datos, se recomienda NO incluir LazyData: TRUE. Incluirlo en ese caso, ralentiza la carga de paquetes con datos grandes. Dependencias Todos los paquetes deben estar disponibles a través de biocViews o CRAN de Bioconductor; el uso del campo Remotes: no es soportado, por lo tanto las dependencias sólo disponibles en otros repositorios (e.g. GitHub) no están permitidas. Un paquete puede ser listado sólo una vez entre Depends, Imports, Suggests, o Enhances: Imports: es para paquetes que proporcionan funciones, métodos o clases que se usan dentro del código del paquete. La mayoría de los paquetes están listados aquí. Depends: es para paquetes que proporcionan funcionalidad esencial para los usuarios del paquete, por ejemplo, el paquete GenomicRanges se enumera en el campo Depends: de GenomicAlignments. Es poco común que más de tres paquetes aparezcan como Depends:. Suggests: es para paquetes usados en viñetas, ejemplos y código condicional. Comúnmente, los paquetes de anotaciones y experimentos (por ejemplo, TxDb*) usados en viñetas y código de ejemplo se incluyen en este campo, evitando así una descarga costosa. Enhances: es para paquetes como parallel que mejoran el rendimiento del paquete, pero no son estrictamente necesarios para su funcionalidad. En el caso de que se requiera una función única externa para el código del paquete, la disponibilidad y el uso del paquete pueden hacerse a través de: if (!requireNamespace('suggPKG', quietly = TRUE)) stop("Install 'suggPKG' to use this function.") suggPKG::function() biocViews Este campo es obligatorio! Especifica al menos dos biocViews. Los términos deben provenir del mismo tipo de paquete (Software, AnnotationData, ExperimentData o Workflow). Puedes encontrar más información en: https://www.bioconductor.org/packages/release/BiocViews.html BugReports Se recomienda apuntar hacia el repositorio de GitHub, por ejemplo: https://github.com/usuario/paquete/issues. URL Se incluyen los links importantes, como el repositorio con el código fuente y el sitio web de pkgdown si se cuenta con él. Por ejemplo: https://github.com/usuario/paquete https://usuario.github.io/paquete 4.5 Modificando el archivo NEWS Secciones: New: Nuevas funciones. Bug fixes: Reparación de errores en las funciones previas o en la documentación. Changes: Cambios en el código de las funciones, incluyendo modificaciones en los argumentos. Breaking changes: Cambios importantes que romperían el código en caso de no ser atendidos, por ejemplo el uso de funciones o argumentos antiguos. Enhancements: Mejoras a las funciones existentes. Formato El archivo NEWS se ve similar a este ejemplo: "],["creando-mis-primeras-funciones.html", "5 Creando mis primeras funciones 5.1 Diapositivas", " 5 Creando mis primeras funciones Instructora: Joselyn Chávez 29 de octubre de 2024 5.1 Diapositivas "],["documentación-de-funciones.html", "6 Documentación de funciones 6.1 Diapositivas 6.2 Links importantes: 6.3 ¿Qué es la documentación de una función y por qué es importante? 6.4 Generacion de la documentacion con ayuda del paquete roxygen 6.5 Antes de empezar…✏️ 6.6 Generacion de un bloque de documentacion con ayuda del paquete roxygen. 6.7 Otros campos de la documentacion.", " 6 Documentación de funciones Instructor/a: 29 de octubre de 2024 6.1 Diapositivas 6.2 Links importantes: Esta lección está basada en algunos manuales sobre documentación: Una viñeta del cranproject El manual de paqutes de r En esta viñeta de cranproject 6.3 ¿Qué es la documentación de una función y por qué es importante? 🙇️ Es la información complementaria que el desarrollador escribe sobre una función y que se accede con ? seguido el nombre de una función actual de un paquete p.ej. ?unafuncion. 📁 La documentación se almacena como un archivo .Rd (“R documentation) en la carpeta man/. 🔎 La documentación usa una síntesis especial, que es distinta a la de r y que está ligeramente basada en LaTeX. 📄 Se puede renderizar como html, pdf o texto sin formato según se necesite. 6.4 Generacion de la documentacion con ayuda del paquete roxygen En un paquete de r y en cualquier ecosistema de devtools no editamos un documento .Rd manualmente. La documentación usa una síntesis parecida a LaTex que puede ser fácil de estropear. Por ventaja existen paquetes como roxigen2. Usar roxigen nos permite usar comentarios especiales sobre el inicio de la función, esto nos da un par de ventajas: ✅ La documentación y la función estarán en un mismo lugar, por lo que si editas la función será mas fácil recordar actualizar la documentcion también. 🎉 Puedes usar markdown en lugar de la síntesis especial para los archivos .Rd 6.5 Antes de empezar…✏️ Vamos a crear un función para nuestro paquete. Supongamos que para nuestro paquete necesitamos una función que calcule la moda. Esta es una forma sencilla de calcular la moda: getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } unique(serievector): Crea un vector que contiene únicamente los valores únicos de la serie de números serievector. match(serievector, uniqv): Encuentra la posición de cada valor de serievector en el vector único uniqv. tabulate(match(serievector, uniqv)): Cuenta cuántas veces aparece cada valor en la serie serievector. which.max(tabulate(match(serievector, uniqv))): Encuentra el índice del valor máximo en el vector de frecuencias. uniqv[which.max(tabulate(match(serievector, uniqv)))]: Devuelve el valor correspondiente al índice calculado, que es la moda. Creamos un ejemplo para ver que funcione: serie_numeros <- c(1, 2, 2, 2, 2, 3, 3, 4, 4, 4) resultado <- getmode(serie_numeros) print(resultado) ## [1] 2 Bien ahora si podemos podemos empezar a usar el paquete de roxygen para documentar nuestra función.. comencemos. 6.6 Generacion de un bloque de documentacion con ayuda del paquete roxygen. Podemos insertar un esqueleto de comentarios de roxygen para ver su síntesis. Colocamos el cursor en algún lugar de la definición de nuestra función y buscamos en la pestaña Código > Insertar Roxygen Skeleton. #' Title #' #' @param serievector #' #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Ahora ya tenemos un esqueleto de la documentación que nos da una ventaja para su creación. Las líneas de comentarios de Roxygen siempre comienzan con #', el habitual para un comentario # mas un ' Veamos los comentarios de uno por uno: Empezamos con el titulo. Se sugiere poner en el titulo las acciones principales que realiza la función en este caso por ejemplo podremos usar: #' @title Encontrar la Moda de una Serie de Números #' #' @param serievector #' #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Muy bien!. El siguiente comentario que podemos ver es @param. Pero antes, vamos a añadir una pequeña descripción de la función y como usarla. Primero añadimos la pequeña descripción con @description: #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' @param serievector #' #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Ahora vamos a añadir el comentario @usage que nos indica como puedes mandar a llamar la función. #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' @usage getmode(serievector) #' @param serievector #' #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Ahora si vamos a añadir una pequeña descripción de nuestros argumentos. Si tuviéramos mas de un parámetro en nuestra función podríamos llamar las veces que sea necesario el comentario de parámetro con @param, veamoslo. Ahora añadimos una pequeña descripción a nuestro único parámetro que es serievector: #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' #' @param serievector Es una serie de números en forma de un vector simple de r. #' #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Después, podemos añadir un comentario de detalles de la función con @details. Por ejemplo, si en nuestro ejemplo tuviéramos ciertos valores no numéricos en nuestro vector de entrada, por ejemplo letras, ¿nuestra función podría leerlas?, o si le diéramos un vector sin caracteres ¿que pasaría?, veamos: serie_numeros <- c(0,2,2,"d", "d","d") resultado <- getmode(serie_numeros) print(resultado) ## [1] "d" serie_numeros <- c() resultado <- getmode(serie_numeros) print(resultado) ## NULL Entonces, esto es un ejemplo de lo que podríamos poner en el comentario @details. Hagamoslo describiendo esto. En details podemos agregar detalles un poco mas específicos que en la descripción de la función #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' #' @param serievector Es una serie de números en forma de un vector simple de r. #' #' @details si tu vector de entrada puede ser interpretado alternando números y #' letras escritas entre comillas "". Si un vector esta vacío, dará como #' resultado un NULL. #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Ya casi terminamos de llenar nuestra documentación, pero antes vamos a ver algunos otros arrobas que pudieran ser importantes. El @import e @importfrom importan funciones de otros paquetes en caso de que las necesitemos, el primero importa todas las funciones del paquete que que solicites, y el segundo importa solo algunas funciones especificas. En nuestra función no necesitamos llamar funciones de otros paquetes puesto que todas las que usamos están en r base. Pero imaginemos que tu función, por ejemplo necesita leer un archivo .tsv con la función read_tsv del paquete readr y después reconvertir la tabla resultante en un archivo con write.table pero solo necesitas esa función del paquete utils, entonces haríamos: #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' #' @param serievector Es una serie de números en forma de un vector simple de r. #' #' @details si tu vector de entrada puede ser interpretado alternando números y #' letras escritas entre comillas "". Si un vector esta vacío, dará como #' resultado un NULL. #' @import readr #' @importFrom utils write.table #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Así podemos importar las funciones que necesitemos de otros paquetes y se incluirán en la documentación y se cargaran automáticamente al cargar tu paquete. :eyes::exclamation: Para un correcto funcionamiento de tu paquete y al estar los paquetes necesarios incluidos en la documentación, no será necesario llamarlos de la forma ``library(“apackage”)```. Entonces llegamos a la sección @return. Esta descripción le servirá al usuario del paquete para conocer cual sera el resultado de la función, que puede ser un archivo, una tabla, un numero,etc. Entonces retomando la función que usamos al inicio, vamos a escribir una descripción corta del resultado de la función getmode(). #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' #' @param serievector Es una serie de números en forma de un vector simple de r. #' #' @details si tu vector de entrada puede ser interpretado alternando números y #' letras escritas entre comillas "". Si un vector esta vacío, dará como #' resultado un NULL. #' @return El carácter con mas frecuencia de el vector de entrada. #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Por ultimo tenemos @export que es el encargado de renderizar la documentación para que pueda aparecer en la ventana de Ayuda (abajo a la derecha). esta opción la dejamos para funciones principales que el usuario va a utilizar, aunque puede que existan alguna funciones internas que no queremos que el usuario vea. En ese caso vamos a usar @noRd en lugar de este. Antes de terminar podemos incluir ejemplos de como funciona nuestra función para un mejor entendimiento, pongamos los que ya realizamos: #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' #' @param serievector Es una serie de números en forma de un vector simple de r. #' #' @details si tu vector de entrada puede ser interpretado alternando números y #' letras escritas entre comillas "". Si un vector esta vacío, dará como #' resultado un NULL. #' @return El carácter con mas frecuencia de el vector de entrada. #' @export #' #' @examples #' serie_números <- c(1, 2, 2, 2, 2, 3, 3, 4, 4, 4) #' resultado <- getmode(serie_números) #' print(resultado) getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Ahora si, una vez teniendo listo el bloque de comentarios para la documentación, vamos a ejecutar devtools::load_all() para cargar nuestras funciones y hecho esto, ejecutamos devtools::document() o presionamos Ctrl/Cmd + Shift + D para convertir los comentarios en archivo .Rd y poder renderizarlo. 💯 Listo, tenemos nuestra documentación para una función. Así se verá cuando el paquete esté terminado. 6.7 Otros campos de la documentacion. @seealso para indicar funciones relacionadas y facilitar la búsqueda de funciones. @references añade algunas referencias. @author para especificar el autor de la función. "],["diseño-de-pruebas.html", "7 Diseño de pruebas 7.1 Diapositivas", " 7 Diseño de pruebas Mirna Vázquez Rosas-Landa 30 de octubre de 2024 7.1 Diapositivas "],["creación-de-viñetas.html", "8 Creación de viñetas 8.1 Diapositivas 8.2 ¿Qué es una viñeta? 8.3 Características de una vignette 8.4 ¿Cómo consultar la viñeta de un paquete? 8.5 ¿Cómo crear una viñeta? 8.6 ¿Cómo guardar y actualizar la viñeta? 8.7 Veamos un ejemplo 8.8 Actividad", " 8 Creación de viñetas José Antonio Ovando Ricárdez 30 de octubre de 2024 8.1 Diapositivas 8.2 ¿Qué es una viñeta? Es una guía extendida sobre cómo funciona el paquete. Es recomendable que muestre cómo utilizar las funciones del paquete, aplicado en un flujo de trabajo; por ejemplo: el análisis estadístico de una encuesta o el análisis de expresión diferencial de genes. Podemos estructurarlo como haríamos con la escritura de un capítulo de libro o de un artículo científico: debe mostrar el problema a resolver y la metodología paso a paso sobre cómo el paquete lo resuelve. Si el paquete contiene funciones que se complementan entre sí para alcanzar un fin específico, entonces debes mostrar su uso de forma compartamentalizada. 8.3 Características de una vignette Debe mostrar un flujo de análisis explotando el potencial de tu paquete. Implementa tantas funciones de tu paquete como sea posible, pero no es necesario que incluya todas. Los datos a usar deben ser pequeños o fáciles de acceder. Puedes crear múltiples viñetas para mostrar diferentes casos de análisis y cubrir una mayor cantidad de funciones. 8.4 ¿Cómo consultar la viñeta de un paquete? browseVignettes(package = "ggplot2") 8.5 ¿Cómo crear una viñeta? biocthis::use_bioc_vignette("mi_vignette") Esta función tendrá tres efectos: Generar el directorio vignettes en caso que no exista. Agregar dependencias en el archivo DESCRIPTION (por ejemplo, knitr necesario para construir viñetas dentro del paquete). Abrir un templado en formato .Rmd para comenzar a escribir la viñeta, que se va a guardar en vignettes/mi_vignette.Rmd 8.6 ¿Cómo guardar y actualizar la viñeta? Una vez que se ha generado el archivo vignettes/mi_vignette.Rmd se hacen las modificaciones necesarias. Puedes usar el comando: edit_file("vignettes/mi_vignette.Rmd") Para guardar los cambios debes hacer click en el botón Knit o utiliza la combinación de teclas Ctrl/Cmd-Shift-K. 8.7 Veamos un ejemplo Busca la viñeta del paquete regutools en la página de Bioconductor https://bioconductor.org/packages/release/bioc/html/regutools.html 8.8 Actividad Escribe una viñeta que muestre cómo utilizar las funciones para cargar y filtrar los datos de pbmc. "],["compilación-e-instalación-de-paquetes.html", "9 Compilación e instalación de paquetes 9.1 Diapositivas 9.2 Metadatos de una paquetería 9.3 Licencias 9.4 Paqueterías de código fuente 9.5 ¿En dónde podemos encontrar el código fuente de un paquete? 9.6 Instalando la última versión en desarrollo 9.7 Instalando paquetes desde GitHub 9.8 Instalando un paquete local 9.9 Contribuyendo código", " 9 Compilación e instalación de paquetes Joselyn Cristina Chávez Fuentes 30 de octubre de 2024 9.1 Diapositivas 9.2 Metadatos de una paquetería Los metadatos de la paquetería se encuentran en el archivo DESCRIPTION. 9.2.1 Description El campo Description describe lo que hace tu paquetería. Suele ser extenso, si requieres escribir múltiples líneas, deben estar indentadas. Por ejemplo: # Description: Este paquete contiene todas las funciones generadas en el curso # de escritura de paqueterías en R. También contiene las funciones que cada # participante propuso para solucionar un problema relacionado con su trabajo. 9.2.2 Dependencias Las dependencias son las paqueterías que tu paquete necesita para funcionar. La lista de paquetes se escribe separada por comas y es recomendado que se escriban en orden alfabético. Existen tres tipos: Imports: Son paquetes que deben instalarse para que tu paquete funcione y por tanto se van a instalar en el momento que instales el paquete. Internamente existe una función que evalúa si los paquetes se encuentran instalados o no y solamente instala los faltantes. Esta dependencia hace solamente la instalación pero no ejecuta library(), por lo que los paquetes requeridos deberán ser cargados dentro de la escritura del paquete. Depends: Son paquetes que obligatoriamente deben estar para que tu paquetería funcione pero no se instalarán de manera automática. Aquí también se indica la versión de R requerida para el funcionamiento del paquete. Los paquetes que se listen aquí se van a cargar al mismo tiempo que se ejecute el library(mipaquete). Suggests: Se refiere a los paquetes que tu paquete puede utilizar y aprovechar para ser más poderoso en el análsis pero no los necesita para funcionar. Por ejemplo, paquetes que contienen sets de datos para hacer pruebas o análisis de práctica. Nota Importante Se recomienda listar los paquetes necesarios para el funcionamiento de nuestro paquete en Imports porque cuando se ponen en Depends se cargan los paquetes completos y probablemente solamente requerimos una o dos funciones. Cargar demasiados paquetes completos, sin ser necesario, sólo hace que nuestro paquete se vuelva pesado y lento. Es mejor llamar particularmente a las funciones usando la sintaxis explícita: Biostrings::translate() 9.2.3 ¿Cómo añadir dependencias? Usando usethis: usethis::use_package("ggplot2", type = "Imports") Editando manualmente el archivo DESCRIPTION. 9.3 Licencias Establece quién puede usar tu paquete. Existen diversas licencias pero hablaremos sobre las 3 más comunes: MIT (Massachusetts Institute of Technology): es simple y permisiva. Permite a cualquier persona usar y distribuir tu paquetería con una sola restricción: la distribución debe incluir la declaración de licencia del autor. Existe un texto base al cual se le pueden añadir cláusulas o excepciones. Este es un ejemplo: GPL-2 (General Public License): Permite usar y distribuir tu código con la condición que si se genera una versión modificada de tu código, su distribución debe ser también bajo esta licencia. Aunque está enfocada a la distribución de código abierto, permite dejar en claro quién es el autor del material y evitar la apropiación del código por terceros. Un ejemplo de la aplicación de esta licencia es el desarrollo de Linux. CCO: Esta licencia implica que cedes todos los derechos y el código puede ser utilizado con cualquier fin, excepto fines comerciales. Es el más utilizado en los paquetes. Concede el derecho a utilizar y distribuir el material sin requerir el permiso del autor. 9.4 Paqueterías de código fuente En algunas ocasiones necesitaremos instalar paquetes que no se encuentran compilados, por ejemplo: Paquetes en desarrollo de CRAN o Bioconductor. Versiones anteriores de paquetes de CRAN o Bioconductor. Paquetes que no se encuentran depositados en CRAN o Bioconductor, sino en repositorios personales como GitHub. Paquetes que estás desarrollando de forma local. El paquete remotes será de gran utilidad. Regularmente, los paquetes que instalamos desde algún repositorio como CRAN o Bioconductor son paquetes binarios que ya se encuentran compilados previamente. Existen algunas funciones que nos permiten instalar paquetes desde código fuente. Anteriormente, se solían utilizar las funciones install_* del paquete devtools; sin embargo, recientemente se creó el paquete remotes que contiene las mismas funciones pero está específicamente diseñado para ayudarnos a trabajar con paquetes desde código fuente. 9.5 ¿En dónde podemos encontrar el código fuente de un paquete? Si el paquete se encuentra disponible en CRAN, puedes encontrar el link al código fuente en la sección URL. Si el paquete se encuentra disponible en Bioconductor, puedes encontrar el link al código fuente en la sección Package Archives Si el paquete se encuentra en GitHub o GitLab, necesitarás conocer el nombre de usuario y el nombre del paquete. 9.6 Instalando la última versión en desarrollo Si el paquete se encuentra depositado en CRAN podemos usar la función remotes::install_dev("pkgname") Por ejemplo, para instalar la versión en desarrollo de dplyr usaremos el comando remotes::install_dev("dplyr") Si el paquete se encuentra en Bioconductor usaremos la siguiente función: remotes::install_bioc("pkgname") Por ejemplo, para instalar la versión en desarrollo de regutools, el paquete desarrollado por miembros de la CDSB, usaremos el comando remotes::install_bioc("regutools") 9.7 Instalando paquetes desde GitHub Para poder instalar un paquete desde GitHub necesitaremos conocer el usuario del creador y el nombre del repositorio. remotes::install_github("usuario/repositorio") Por ejemplo, para instalar el paquete starwarssay desarrollado por Erick Cuevas (Erickcufe) utilizaremos el siguiente comando: remotes::install_github("Erickcufe/starwarssay") Independientemente de si el paquete se encuentra en CRAN, Bioconductor, o ninguno de ellos, podemos instalar un paquete depositado en una cuenta de GitHub. Para poder instalar un paquete desde GitHub necesitaremos conocer el usuario del creador y el nombre del repositorio donde se encuentra depositado el paquete. Con esta información usaremos la siguiente función: 9.8 Instalando un paquete local Paso 1: Abre el proyecto del paquete que estás desarrollando. Paso opcional: Ejecuta la documentación si realizaste algún cambio. devtools::document() Paso 2: Construye el paquete: devtools::build() Paso 3: Instala el paquete desde tu proyecto actual: devtools::install() 9.9 Contribuyendo código Una ventaja de descargar el paquete de forma local es que puedes realizar cambios, probar que funciona de manera local y después contribuir (haciendo un pull-request). Usemos el paquete saludo Clona el repositorio en tu computadora. git clone https://github.com/ComunidadBioInfo/saludo.git Ahora puedes abrir el proyecto del paquete y agregar tu código. "],["creación-de-sitios-web-con-pkgdown.html", "10 Creación de sitios web con pkgdown 10.1 Diapositivas 10.2 Instalación 10.3 Configura el paquete para crear el sitio con pkgdown 10.4 Genera la estructura de pkgdown 10.5 Pre-visualiza el sitio de manera local 10.6 Personalizando el _pkgdown.yml 10.7 Las variables bslib 10.8 Layout 10.9 Accessibilidad 10.10 La página de inicio 10.11 La página de referencias 10.12 Articles 10.13 News 10.14 Publicando el sitio web", " 10 Creación de sitios web con pkgdown Joselyn Cristina Chávez Fuentes 31 de octubre de 2024 10.1 Diapositivas div.grey { background-color: #bfbfbf; } div.center { text-align:center; } 10.2 Instalación install.packages("pkgdown") 10.3 Configura el paquete para crear el sitio con pkgdown Este paso se ejecuta solamente una vez, dentro del proyecto del paquete. usethis::use_pkgdown_github_pages() Este paso genera las acciones automáticas de GitHub para renderizar el sitio. El archivo README.md será tu página de inicio, la documentación en man/ va a crear una sección de referencias, y las viñetas serán renderizadas como articles. 10.4 Genera la estructura de pkgdown Este paso se ejecuta solamente una vez. usethis::use_pkgdown() 10.5 Pre-visualiza el sitio de manera local Este paso lo puedes ejecutar para visualizar el sitio cada vez que hagas una modificación, antes de enviar los cambios a GitHub. pkgdown::build_site() 10.6 Personalizando el _pkgdown.yml 10.6.1 Metadatos URL Este es el link donde se va a renderizar el sitio, revisa que sea correcto y, de ser necesario, actualízalo. url: https://pkgdown.r-lib.org template Esta sección permite personalizar la apariencia general del sitio. template: bootstrap: 5 bootswatch: cerulean 10.6.2 Temas Light switch Puedes proporcionar un “light switch” para permitir a tus usuarios cambiar entre temas oscuros y claros configurando la opción de light-switch a true: template: light-switch: true Bootswatch themes La forma más fácil de cambiar toda la apariencia de tu sitio web es usar un tema de Bootswatch: template: bootstrap: 5 bootswatch: materia Puedes ver los temas disponibles en https://bootswatch.com/ Estos temas suelen no ser compatibles con el light switch, pero puedes intentar. Al cambiar el bootswatch theme necesitas renderizar el sitio para ver por completo los efectos del tema. build_site() Mientras estás experimentando, puedes acelerar las cosas simplemente reconstruyendo la página de inicio y el CSS ejecutando: build_home_index() init_site() y luego actualizando el navegador. Los bootswatch theme con barras de navegación altas (lux, pulse) también requieren que se modifique la variable pkgdown-nav-height. Debido a que los temas de bootswatch son proporcionados por el paquete bslib, se puede anidar el campo bootswatch debajo del campo bslib. template: bootstrap: 5 bslib: bootswatch: lux pkgdown-nav-height: 100px 10.7 Las variables bslib Hay tres variables clave que afectan al color: bg (fondo) determina el fondo de la página. fg (primer plano) determina el color del texto. primary establece el color del enlace y el color translúcido en la barra de navegación y la barra lateral. template: bootstrap: 5 bslib: bg: "#202123" fg: "#B8BCC2" primary: "#306cc9" También se pueden personalizar las fuentes predeterminadas utilizadas para la mayoría del texto (base_font), para los encabezados (heading_font) y para el código (code_font). La forma más fácil es proporcionar el nombre de una fuente de Google con la siguiente sintaxis: template: bootstrap: 5 bslib: base_font: {google: "Roboto"} heading_font: {google: "Roboto Slab"} code_font: {google: "JetBrains Mono"} 10.7.1 Syntax highlighting Los colores utilizados para el resaltado de sintaxis en bloques de código están controlados por la configuración theme: template: bootstrap: 5 theme: breeze-light Puedes elegir entre: a11y-dark, a11y-light, arrow-dark, arrow-light, atom-one-dark, atom-one-light, ayu-dark, ayu-light, ayu-mirage, breeze-dark, breeze-light, breezedark, dracula, espresso, github-dark, github-light, gruvbox-dark, gruvbox-light, haddock, kate, monochrome-dark, monochrome-light, monochrome, monokai, nord, oblivion, printing, pygments, radical, solarized-dark, solarized-light, solarized, tango, vim-dark, zenburn. 10.7.2 Navbar style Los campos bg y type de la barra de navegación controlan los colores del fondo y el primer plano respectivamente. Normalmente bg será light, dark, o primary: navbar: bg: primary 10.8 Layout Puedes personalizar el contenido de la barra de navegación, pie de página, utilizando los campos navbar y footer. Todos ellos utilizan una estructura similar que define por separado la estructura global y los componentes individuales. 10.8.1 Navbar Esta es la estructura default: navbar: structure: left: [intro, reference, articles, tutorials, news] right: [search, github, lightswitch] intro: “Get Started”, enlaza a una viñeta o artículo con el mismo nombre que el paquete. reference: si hay archivos . Rd. articles: si hay viñetas o artículos. tutorials: si hay algún tutorial. news: si existe NEWS.md. search: la barra de búsqueda. github: un enlace al repositorio de origen (con un icono), es determinado automáticamente a partir del archivo DESCRIPTION. lightswitch; un “interruptor de luz” para seleccionar el modo claro, modo oscuro o modo automático. Puedes utilizar el campo structure para reorganizar la barra de navegación: navbar: structure: left: [search] right: [reference, articles] Puedes usar la misma sintaxis para organizar el menú de artículos: navbar: components: articles: text: Articles menu: - text: Category A - text: Title A1 href: articles/a1.html - text: Title A2 href: articles/a2.html - text: ------- - text: "Category B" - text: Article B1 href: articles/b1.html 10.8.2 Footer Esta es la estructura por defecto:: footer: structure: left: developed_by right: built_with Que utiliza dos de los tres componentes incorporados: developed_by: una frase que describe a los principales autores del paquete. built_with: una frase que hace publicidad de la misma. package: el nombre del paquete. Puedes personalizar la organización del pie de página: footer: structure: left: pkgdown right: [developed_by, legal] components: legal: Provided without **any warranty**. 10.9 Accessibilidad Las configuraciones default de pkgdown tratan de hacer el sitio lo más accesible posible para todos, pero hay algunos puntos a tomar en cuenta: 10.9.1 Colores Si ajustas cualquier color del tema default, verifica que el contraste entre el fondo y el primer plano no haga difícil leer ningún texto. Puedes utilizar la herramienta de evaluación de accessibilidad en https://wave.webaim.org. El color default genera un contraste demasiado bajo contra el fondo gris pálido de la barra de navegación. Este color viene de la paleta “danger” de bootstrap, así que puedes arreglarlo sobreescribiendo esa variable en tu _pkgdown.yml: template: bootstrap: 5 bslib: danger: "#A6081A" Si utilizas entradas de barra de navegación personalizadas que sólo muestran un icono, asegúrate de utilizar también el campo aria-label para proporcionar una etiqueta accesible que describa el icono. cran: icon: fab fa-r-project href: https://cloud.r-project.org/package=pkgdown aria-label: View on CRAN 10.9.2 Imágenes Para hacer tu sitio completamente accessible, agrega una descripción del contenido de las imágenes en las viñetas usando el campo “fig.alt” de las opciones del chunk de R. 10.10 La página de inicio Los contenidos del home page son automáticamente generados desde el archivo index.md o el README.md. pkgdown les asigna diferentes prioridades, por lo que es possible tener contenidos diferentes en el repositorio de GitHub y la página de pkgdown si provees ambos archivos. La página de inicio también incluye una barra de contenidos con links importantes, como la guía de contribución, el código de conducta, etc. 10.11 La página de referencias pkgdown crea una página de referencia en reference/ para cada una de las funciones del paquete, basado en la documentación. pkgdown ejecuta todos los ejemplos de las funciones, insertando los resultados renderizados en los archivos HTML generados. Por defecto, pkgdown genera un índice de referencia que es sólo una lista de funciones ordenadas alfabéticamente. El índice es mucho más útil con la curación manual porque las funciones pueden agruparse y describirse en categorías. Cada entrada de referencia puede adoptar una de las tres formas siguientes: Un título, definido por los campos title y desc (descripción) opcionales. Un subtítulo, definido por los campos de subtítulo y desc (descripción) opcionales. Lista de temas definidos por un campo de contenido. Mientras editas el índice de referencias, puedes ejecuar la siguiente función para renderizar solamente el índice, lo que permite ver de forma rápida el efecto de los cambios sin tener que renderizar todo el sitio. pkgdown::build_reference_index() reference: - title: "Connecting to Spark" desc: > Functions for installing Spark components and managing connections to Spark contents: - spark_config - spark_connect - spark_disconnect - spark_install - spark_log 10.12 Articles pkgdown creará automáticamente todas las viñetas que se encuentran en la carpeta vignettes/, traduciéndolas a archivos HTML en articles/. Se puede nombrar el artículo de introducción con el nombre del paquete para generar una página “Get Started” automáticamente. 10.13 News Si el archivo NEWS.md está presente, se procesará en un changelog de una sola página basado en los títulos de las secciones del archivo. pkgdown asume que el archivo NEWS.md está formateado con encabezados de nivel uno (#) para especificar el nombre del paquete y el número de versión, y con encabezados de nivel dos (##) para proporcionar una organización temática para cada versión. # pkgdown 1.1.0 ## Bug Fixes * Lots of them 10.14 Publicando el sitio web Haz commit de los cambios y luego push. Ve al repositorio del paquete en GitHub y espera a que la acción de GitHub termine de renderizar el sitio. Ve al sitio web, el formato debe ser similar a https://usuario.github.io/paquete "],["proyectos-colaborativos-1.html", "11 Proyectos colaborativos 11.1 Propuesta 1 11.2 Propuesta 2 11.3 Propuesta 3 11.4 Propuesta 4 11.5 Propuesta 5", " 11 Proyectos colaborativos 11.1 Propuesta 1 11.2 Propuesta 2 11.3 Propuesta 3 11.4 Propuesta 4 11.5 Propuesta 5 "],["404.html", "Page not found", " Page not found The page you requested cannot be found (perhaps it was moved or renamed). You may want to try searching to find the page's new location, or use the table of contents to find the page you are looking for. "]] +[["index.html", "Desarrollo de paqueterías de R/Bioconductor. Bienvenida 0.1 Instructores 0.2 Ayudantes 0.3 Temario 0.4 Patrocinadores 0.5 Licencia", " Desarrollo de paqueterías de R/Bioconductor. Dra. Joselyn Cristina Chávez-Fuentes, Dra. Mirna Vázquez Rosas-Landa, M.C. Erick Cuevas-Fernández, Dra. Alejandra Medina-Rivera, Bienvenida Les damos la bienvenida al Workshop Desarrollo de paqueterías de R/Bioconductor! En este taller aprenderás cuáles son los pasos cruciales para desarrollar un paquete de R y algunas buenas prácticas para la generación de código. Con la integración de estas herramientas, tendrás la oportunidad de crear tu primer paquete y contribuir a la comunidad de desarrolladores. Adicionalmente, aprenderás a crear un sitio web para mostrar el funcionamiento de un paquete de R. 0.1 Instructores Dra. Joselyn Cristina Chávez Fuentes: Estancia Postdoctoral en Icahn School of Medicine at Mount Sinai. Dra. Mirna Vázquez Rosas Landa: Investigadora en el Instituto de Ciencias de Mar y Limnología de la UNAM. Dra. Alejandra Medina Rivera: Investigadora Asociada en el Laboratorio Internacional de Investigación de Medicina Genómica, UNAM. M.C. Erick Cuevas Fernández: Estudiante de Doctorado en la Universidad Nacional Autónoma de México. M.C. José Antonio Ovando Ricárdez: Estudiante de Doctorado en el Instituto Nacional de Enfermedades Respiratorias Ismael Cosío Villegas. 0.2 Ayudantes Dra. Evelia Coss: Posdoctoral en el Laboratorio Internacional de Investigación de Medicina Genómica, UNAM. M.C. José Antonio Ovando Ricárdez: Estudiante de Doctorado en el Instituto Nacional de Enfermedades Respiratorias Ismael Cosío Villegas. 0.3 Temario Consulta el calendario de este curso en: https://bit.ly/calendarcdsb2024 Día 1: Flujo de trabajo orientado a proyectos: Introducción al trabajo con proyectos de RStudio. Paths seguros. Control de versiones con GitHub y RStudio. Solución de problemas con las versiones de paquetes de Rstudio. Día 2: Creación de paquetes de R/Bioconductor Parte I Infraestructura de un paquete de R/Bioconductor. Documentación de funciones. Sesión social: Conociendo a la comunidad. Proyectos colaborativos Parte I. Día 3: Creación de paquetes de R/Bioconductor Parte II Diseño de pruebas. Creación de viñetas. Compilación e instalación de paquetes. Proyectos colaborativos Parte II. Día 4: Creación de sitios web para la documentación de paquetes de R Creación de sitios web con pkgdown Proyectos colaborativos Parte III. Presentación de proyectos. Clausura. 0.4 Patrocinadores Agradecemos a nuestros patrocinadores: 0.5 Licencia Este material posee una licencia tipo Creative Commons Attribution-ShareAlike 4.0 International License. Para conocer más sobre esta licencia, visite http://creativecommons.org/licenses/by-sa/4.0/ "],["trabajando-con-proyectos-de-rstudio.html", "1 Trabajando con proyectos de RStudio 1.1 Diapositivas 1.2 ¿Qué es un proyecto de RStudio? 1.3 ¿Cómo generamos un proyecto de RStudio? 1.4 ¿Por qué usar proyectos de RStudio? 1.5 Algunos hacks! 1.6 Generando rutas seguras", " 1 Trabajando con proyectos de RStudio Joselyn Cristina Chávez Fuentes 28 de octubre de 2024 1.1 Diapositivas div.grey { background-color: #bfbfbf; } div.center { text-align:center; } 1.2 ¿Qué es un proyecto de RStudio? Es un archivo especial de R, compatible con RStudio, que al ejecutarlo hará 3 cosas: Abrirá una nueva sesión de RStudio. Establecerá la ubicación del proyecto como tu directorio de trabajo. Establecerá la ubicación del proyecto como la raíz de los archivos. 1.3 ¿Cómo generamos un proyecto de RStudio? 1.3.1 Opción 1: Creando un proyecto en un directorio nuevo. En las opciones de RStudio Ve a File > New project > New Directory > New Project. Asigna un nombre a tu proyecto, sin espacios y sin caracteres especiales. Selecciona la ubicación donde crearás el nuevo directorio. Selecciona la opción Open in New Session. Oprime Create Project. 1.3.2 Opción 2: Creando un proyecto en un directorio existente. Crea un directorio en alguna ubicación conocida de tu computadora. Asigna un nombre a tu directorio, sin espacios y sin caracteres especiales (Este será el nombre de tu proyecto). En las opciones de RStudio ve a File > New project > Existing Directory. Selecciona la ubicación donde previamente creaste el directorio. Selecciona la opción Open in New Session. Oprime Create Project. 1.4 ¿Por qué usar proyectos de RStudio? Te permiten ser más organizado y pasar de tener una ensalada de archivos a tener carpetas para cada sección del análisis. Compartamentalizas tu trabajo al generar un proyecto específico para cada análisis. Te permiten trabajar con varios proyectos a la vez en sesiones independientes de RStudio, cada uno con sus propias variables, directorio de trabajo y archivos. Establece automáticamente tu directorio de trabajo. En lugar de usar setwd() solamente requieres ejecutar el archivo .Rproj para abrir la sesión y trabajar en la ubicación del proyecto. Puedes usar rutas relativas (y estables) a tus archivos, que seguirán funcionando sin importar en dónde se ubique tu proyecto. Facilita el compartir y reproducir tu trabajo. No más rutas al estilo ~/MiComputadora/MiFolder/MiArchivo. Comparte la carpeta completa de tu proyecto con todos los archivos necesarios y usa rutas relativas dentro del Rscript, por ejemplo ./datos. Nos ayuda a establecer colaboraciones y trabajar con plataformas de control de versiones. Actividad Comprueba algunas ventajas de usar proyectos de RStudio. Genera un nuevo proyecto de RStudio llamado ‘miproyecto’, recuerda que existen varias formas para hacerlo. Cierra la sesión y vuelve a abrirla ejecutando desde la terminal open miproyecto.Rproj o dando doble click sobre el archivo miproyecto.Rproj. Evalúa tu directorio de trabajo ejecutando en la consola de RStudio el comando getwd(). Cierra la sesión y mueve toda la carpeta de tu proyecto a otra ubicación. Si lo creaste en Documentos mueve la carpeta al Escritorio o viceversa. Abre nuevamente el proyecto y verifica el directorio de trabajo, ¿Cambió el directorio de trabajo? Sin cerrar este proyecto, abre alguno de los proyectos que generaste previamente (por ejemplo directorioprevio.Rproj), recuerda que puedes seleccionar Open Project in New session 1.5 Algunos hacks! RStudio recuerda los proyectos con los que has trabajado recientemente. Ve a la esquina superior derecha y da click en la flecha junto al nombre de tu proyecto actual. Verás todos los proyectos recientes. Si das click en el nombre de alguno de ellos te abrirá el proyecto en la misma sesión, si das click en el recuadro con flecha blanca te abrirá una nueva sesión con tu proyecto. Crea todos tus proyectos dentro de una carpeta principal y usa el buscador de archivos para acceder a ellos rápidamente. 1.6 Generando rutas seguras Se construyen a partir de una base estable El directorio de trabajo cambia de usuario a usuario y dependiendo de la ubicación de los archivos. getwd() Deben funcionar en cualquier sistema operativo Una ruta en sistemas Linux se ve así: "/Users/joselynchavez/Documents/materiales_cdsb2024" Mientras que una ruta en Windows se ve así: "C:\\Documents/materiales_cdsb2024" 1.6.1 El paquete here Usemos el paquete here para detectar la ubicación del proyecto: here::here() Ahora generemos una ruta segura a partir de la raíz del proyecto here::here("mi_tabla.csv") here::here("subfolder", "mi_tabla.csv") 1.6.2 Usando el paquete fs Por defecto, usa el directorio de trabajo actual como base y detecta el sistema operativo automáticamente. fs::path("mi_tabla.csv") fs::path("subfolder", "mi_tabla.csv") Tiene como ventaja que puede construir las rutas a partir del home del usuario. fs::path_home() fs::path_home("mi_tabla.csv") 1.6.3 Usando funciones base Si no deseas incluir el paquete ‘here’ en las dependencias de tu paquete, puedes usar la función file.path Esta función usa como base el directorio de trabajo actual y detecta el sistema operativo para construir la ruta. file.path("mi_tabla.csv") file.path("subfolder", "mi_tabla.csv") "],["control-de-versiones-con-github-y-rstudio.html", "2 Control de versiones con GitHub y RStudio 2.1 Diapositivas 2.2 ¿Por qué hacer control de versiones de nuestros proyectos? 2.3 Git 2.4 Recomendaciones para sus proyectos 2.5 Proyectos colaborativos 2.6 GitHub 2.7 Manual de sobreviviencia con Git Y GitHub en RStudio (en caso de ser necesario) 2.8 Cómo clonar un repositorio y tener conección/permisos para modificarlo? 2.9 Credenciales HTTPS en Cache 2.10 Conectando RStudio con Git y Github. 2.11 GitHub primero, RStudio después… 2.12 Rmarkdown en GitHub 2.13 RStudio primero y GitHub también 2.14 Proyecto existente, GitHub al final 2.15 Git basics: commands 2.16 Merge conflics 2.17 Merge conflics 2.18 En resumen", " 2 Control de versiones con GitHub y RStudio Dra. Alejandra Medina Rivera 28 de octubre de 2024 div.color { border-radius: 5px; padding: 20px; margin: 30px 0px 30px;} div.red { background-color:#f67155; } div.orange{ background-color:#f0BB51;} div.pair { display: flex; flex-direction: row; justify-content: center; text-align:center; padding:0px} div.inside { width: 49%; padding: 0px} div.scroll { max-height: 400px; overflow-y: auto; background: #111111; border-radius:5px; padding: 10px; margin: 30px 0px 30px; color: #999999;} div.alert{color:#bd475d; background-color:transparent} Este documento se basa en “Happy Git with R” de Jenny Bryan, los STAT 545 TAs, Jim Hester https://happygitwithr.com 2.1 Diapositivas 2.2 ¿Por qué hacer control de versiones de nuestros proyectos? ✅ Los proyectos suelen cambiar y crecer. 💾 Es díficil saber cuáles fueron todos los cambios a lo largo del tiempo (en especial tiempos largos, hazlo por tu yo del futuro!). 🤔 Las colaboraciones se pueden complicar sin un buen control de versiones. 🔐 Seguridad. 2.3 Git Git es un sistema de control de versiones Git funciona con GitHub, Bitbucket o GitLab ¿Por qué usar Git en vez de solo renombrar los archivos? ✅✅Por qué es mejor tener una filogenia del archivo. Git es un sistema de control de versiones distribuido, gratuito y de código abierto, diseñado para manejar todo tipo de proyectos, desde los más pequeños hasta los más grandes, con rapidez y eficiencia. Git es fácil de aprender y ocupa poco espacio con un rendimiento rapidísimo. Supera a las herramientas SCM como Subversion, CVS, Perforce y ClearCase con características como la ramificación local barata, las cómodas áreas de preparación y los múltiples flujos de trabajo. 2.3.1 Git vs controles de versión a mano Con Git cada contribuidor tiene una copia del repositorio central, con todos los archivos y la historia de los cambios por los que han pasado. Excuse me, do you have a moment to talk about version control?, Jennifer Bryan, 2017 ⚠️ NO OLVIDES TENER INSTALADO Git, en caso de que aún no lo hayas instalado, lo puedes descargar en el siguiente enlace https://git-scm.com/downloads. Para conocer la localización y la versión de Git que tienes en tu computadora, corre el siguiente comando en la terminal: which git y git --version 2.4 Recomendaciones para sus proyectos Dedicar un directorio Es mejor organizarlo en un RStudio Project Hacer un repositorio de Git Trabajen como siempre, solo además de guardar, recuerden hacer commit De vez en vez hagan push de sus cambios cuando los hayan verificado. 2.5 Proyectos colaborativos GitHub se parece más a un GoogleDoc que a un Word Document. Es fácil que los colaboradores hagan cambios y también es fácil saber quién hizo que. El owner del proyecto puede dar permisos a los diferentes colaboradores. También existen organizaciones, esto puede ser útil para manejar los permisos de grupos grandes de colaboración. 2.6 GitHub GitHub es una plataforma para guardar proyectos, hace uso de Git. Su principal utilidad es para generar código fuente de programas. ⚠️ NO OLVIDES TENER UNA CUENTA EN GITHUB, en caso de que aún no lo hayas hecho, puedes ir la página de GitHub y seleccionar join. Es indispensable tu usuario para los ejercicios que siguen. También existen otras plataformas como Bitbucked y GitLab, las cuales funcionan de manera similar a GitHub. 2.7 Manual de sobreviviencia con Git Y GitHub en RStudio (en caso de ser necesario) Por cualquier problema con la conexión entre RStudio y Git, siempre ten en cuenta la ubicación de dónde se instaló Git. Puedes usar en la terminal which git (Mac y Linux) O bien usar en la terminal where git (Windows) Recuerda que la terminal (o línea de comandos ó consola ó shell ó bash) es un programa en tu computadora que funciona para correr otros programas. Desde RStudio puedes abrir la terminal, lo cual es muy conveniente si estás trabajando en un proyecto. Puedes abrir una terminal con: Tools > Terminal (abre la terminal dentro del IDE de RStudio) Tools > Shell (abre una terminal externa a RStudio) 2.8 Cómo clonar un repositorio y tener conección/permisos para modificarlo? Git puede comunicarse con un servidor remoto usando uno de dos protocolos, HTTPS o SSH, y cada protocolo usa credenciales diferentes. La recomendación actual de GitHub es usar HTTPS porque es la manera más fácil de configurar y tiene operabilidad en multiples redes y plataformas. Es menos probable que HTTPS sea bloqueado por un firewall. Una conexión HTTPS permite que credential.helper almacene en caché su contraseña. (por tanto puedes configurar tu usuario y contraseña en tu equipo de uso) Es más sencillo acceder a un repositorio desde cualquier lugar, ya que solo necesitas los detalles de tu cuenta (no se requieren claves SSH) para escribir en el repositorio. Usualmente cuando inicies un proyecto colaborativo con GitHub inicializa el ropositorio con un README. Copia el HTTPS URL para clonar el repositorio en la terminal git clone https://github.com/TU-USUARIO/TU-REPOSITORIO.git. 2.9 Credenciales HTTPS en Cache Para usar HTTPS debes crear un token de acceso personal, PAT (PERSONAL ACCESS TOKEN), esa será tu credencial para HTTPS. Es una alternativa al uso de contraseñas para la autenticación en GitHub. Como precaución de seguridad, GitHub elimina automáticamente los tokens de acceso personales que no se han usado durante un año. ¿Cómo crear un token? Ve a tu perfil de GitHub, dale click a la imagen de perfil (usualmente en la esquina superior derecha), y busca la opción de settings ó configuración según sea la configuración de idioma que tengas. Da click a continuación en Developer settings ó Parámetros del desarrollador. En la barra lateral izquierda da click en Tokens de acceso personal. Haz click en Generar un nuevo token. Asígna un nombre descriptivo a tu token. Selecciona los alcances o permisos que deseas otorgarle a este token. Para usar tu token para acceder a repositorios desde la línea de comando, selecciona repo. (Recomendados: repo, user, workflow ) Finalmente haz click en generar token. Listo, copia y pega tu token en el lugar dónde siempre lo puedas volver a copiar, ya que por razones de seguridad, una vez salgas de la página no podrás volver a ver el token. Nota: Preserva tus tokens de la misma manera que tus contraseñas y no se las reveles a nadie. Una vez que tengas un token, puedes ingresarlo en lugar de tu contraseña cuando realices operaciones de Git a través de HTTPS. El punto final es que una vez configurada una PAT, varios paquetes de R, incluidos usethis y gh, podrán trabajar con la API de GitHub en su nombre, de forma automática. Por lo tanto, una PAT configurada correctamente significa que todo esto funcionará a la perfección: - Operaciones HTTPS remotas a través de la línea de comando Git y, por lo tanto, a través de RStudio - Operaciones HTTPS remotas a través del paquete gert R y, por lo tanto, usethis - Operaciones de la API de GitHub a través del paquete gh R y, por lo tanto, usethis Probar el repositorio Clonado Después de hacer clone Usa estos comandos para verificar tu repositorio y revisar desde dónde se está sincorinzando. cd myrepo ls -la head README.md git remote show origin Probemos haciendo un cambio en el README echo "Something I want to add to the README in my local computer" >> README.md git status Qué pasó? Ahora tenemos que decirle a git que queremos seguir los cambios de ese archivo Vamos a commit los cambios y luego a subir (push) los mismos a GitHub git add README.md git commit -m "A commit from my local computer" git push Recuerda tu TOKEN!! ¿Cómo crear un token desde R? Puedes ir directamente a la página de GitHub a la parte para generar tu token de acceso personal mediante la siguiente función: usethis::create_github_token() Y con las opciones que se mencionaban anteriormente puedes configurar y crear tu PAT. Si lo que quieres es especificar tu PAT en RStudio, las siguientes funciones te serán útiles: library(gitcreds) gitcreds_set() library(credentials) set_github_pat() Para eliminar credenciales utiliza la función credentials::git_credential_forget() 2.9.1 Actividad Ejecuta los códigos y genera tu PAT, recuerda no perderlo! 2.10 Conectando RStudio con Git y Github. Para lo que sigue a continuación, deberías tener esto: Tener una cuenta en GitHub R y RStudio actualizados Git instalado Saber que desde la terminal puedes hacer push y pull 2.11 GitHub primero, RStudio después… Crea un repositorio en GitHub: mi_repositorio > Public > YES initialize this repository with a README > clicken el gran botón verde “Create repository” En RStudio crea un nuevo proyecto: File > New Project > Version Control > Git. Ahi pega el URL del repositorio https://github.com/mi_usuario/mi_repositorio.git. Da click en Create Project. Esto nos generará los siguientes elementos: Un directorio nuevo Un repositorio Git enlazado a al repositorio de GitHub Un proyecto en RStudio Con este procedimiento ya no es necesario preocuparse por configurar controles remotos Git y rastrear ramas en la línea de comandos. 2.11.1 Actividad Genera un repositorio con el nombre que desees. Y conéctalo a RStudio. Cerciorate de que el archivo README se encuentre en tu nueva carpeta. Usa la función usethis::use_r(\"titulo_de_un_script\") y observa lo que sucede. PAUSA ¿Cómo comento y doy push/pull desde RStudio? 2.11.2 Comentar, pull y push Con la flecha azul podemos hacer pull (RECUERDA HACERLO ANTES DE HACER UN PUSH), y con la flecha verde un push. Para poder comentar y hacer push debemos marcar con una flechita mediante un click en las pequeñas cajas blancas de la columna Staged, damoc click en commit lo cual no abre la siguiente ventana. Volvemos a dar click en commit, y finalizamos con push (flecha verde). 2.12 Rmarkdown en GitHub Creemos un Rmakrdown y subámoslo a GitHub Ahora hay que agregarlo al repositorio (add), stage and commit. Subieron el hmlt? Qué tal se ve? No se ve como queremos, verdad? Para eso necesitamos recuperar el .md. El .md es un resultado intermedio de crear el html desde Rmd. Tenemos que cambiar el header para esto --- title: "RmarkwondTest" output: html_document: keep_md: true --- 2.12.1 Actividad Usa el código dir.create(\"mis_imagenes\") en la consola de tu sesión de RStudio (la que está vinculada a tu repositorio). Ejecuta el siguiente código quitando los #: install.packages("MASS") library (MASS) data(MASS::cats) # pdf("mis_imagenes/cats_plot.pdf") ggplot(cats, aes(x = Sex)) + geom_bar(fill = "orange", color = "black") + theme_classic() + xlab("Sexo") + ylab("Número de Gatos") + ggtitle("Gatos") # dev.off() Comenta y da push a los cambios que realizaste en el repositorio. 2.13 RStudio primero y GitHub también Usa uno de los proyectos que hayas generado en las sesiones anteriores, PERO, que no esté enlazado a GitHub. Ahora veremos como conectar un proyecto de R existente con GitHub. Realiza los pasos que hicimos en GitHub primero, RStudio después pero asegurate de crear un repositorio con un nuevo nombre. Y LISTO!! usa un simple ctrl + c, ó mv ó click derecho + copiar ó el método que prefieras para mover o copiar archivos. Copia los archivos de tu antigüo proyecto al proyecto nuevo. Solo haz commit y push y listo, lo que tenía en tu antigüo proyecto ya está enlazado a GitHub. 2.14 Proyecto existente, GitHub al final Supongamos que tenemos un proyecto de R existente en algún lugar de nuestra computadora. NOTA: Para generar proyecto de RStudio desde la consola puedes utilizar el siguiente código: usethis::create_project() O en RStudio con File > New Project > Existing Directory Si su proyecto ya es un proyecto de RStudio, ejecútelo. ¿Ya es un repositorio de Git? La presencia del panel de Git debería alertarlo. Si es así, ha terminado. Sino este es el primer camino a seguir: Con el páquete usethis usa la función usethis::use_git En RStudio ve a Tools > Project Options > Git/SVN. Dentro de Version control system, selecciona Git. Y da click a “Yes” cuando aparezca “Confirm New Git Repository?”. Si usaste RStudio o usethis, el proyecto debería reiniciarse en RStudio. Hazlo tu mismo si hizo git init. RStudio ahora debería tener un panel Git. 2.14.1 Breviario cultural con los PATs Si usas el paquete usethis Y has configurado un token de acceso personal (PAT) de GitHub has esto en R: usethis::use_github() Esto creará un nuevo repositorio en GitHub, lo agregará como un control remoto, configurará una rama de seguimiento y lo abrirá en su navegador. Lea la ayuda de use_github() para conocer sus argumentos y consejos sobre cómo configurar una PAT. Esto es extremadamente útil para una variedad de flujos de trabajo que llaman a la API de GitHub. Considere configurar esto si usa usethis, devtools o gh con regularidad. Volviendo al tema de Proyecto existente, GitHub al final. Otra opción que se puede hacer para conectar un proyecto existen a GitHub es ir a hacer un repositorio a GitHub PERO ten en cuenta los siguientes cambios: Elije un nombre de repositorio; probablemente debería coincidir con el nombre de su proyecto y directorio local. NO inicialice este repositorio con un archivo README. Todo lo demás es igual a los pasos que hacíamos en GitHub primero, RStudio después… Ahora ve a tu proyecto de RStudio, has clic en los “dos cuadros de color púrpura y un cuadrado blanco” en el panel de Git. Has clic en “Agregar control remoto”. Pegue la URL aquí y elija un nombre remoto, casi con certeza el origin. Ahora “ADD”. Pasado esto deberiamos volver en el cuadro de diálogo “New Branch”. Ingresa “master” como el nombre de la rama y asegúrate de que la opción “Sync branch with remote” esté marcada. Haz clic en “Create”. En el siguiente cuadro de diálogo elije “overwrite”. Ahora solo haz commit/pull/push y cérciorate que FUNCIONE!! 2.15 Git basics: commands Fetch Commits git fetch Create and Switch to a branch git branch [branch-name] git checkout [branch-name] 2.16 Merge conflics A veces, no tan a veces también, las cosas no salen bien a la primera Merging (Fusionar) es una de esas cosas Cuando bajamos un cambio o fusionamos branches esto puede pasar. Primera regla: NO ENTRAR EN PANICO!!! Revisen el status del repositorio. Qué archivo tiene conflicto? 2.17 Merge conflics Abran ese archivo y busquen los problemas de merge. Es fácil, se ven así: <<<<<<< HEAD:index.html <div id="footer">contact : email.support@github.com</div> ======= <div id="footer"> please contact us at support@github.com </div> >>>>>>> issue-5:index.html Editen esa sección, dejen una versión final. Hagan commit y push Si entran en pánico? Aborten la misión! git merge --abort t 2.18 En resumen ¡QUE LA FUERZA TE ACOMPAÑE! "],["solución-de-problemas-con-las-versiones-de-paquetes-de-rstudio.html", "3 Solución de problemas con las versiones de paquetes de Rstudio 3.1 Diapositivas", " 3 Solución de problemas con las versiones de paquetes de Rstudio Yalbi Balderas 28 de octubre de 2024 3.1 Diapositivas "],["creando-la-infraestructura-de-un-paquete.html", "4 Creando la infraestructura de un paquete 4.1 Diapositivas 4.2 Los primeros pasos 4.3 Checks 4.4 Modificando el archivo DESCRIPTION 4.5 Modificando el archivo NEWS", " 4 Creando la infraestructura de un paquete Joselyn Cristina Chávez Fuentes 29 de octubre de 2024 4.1 Diapositivas 4.2 Los primeros pasos Revisar si podemos usar el nombre del paquete available::available("mipaquete") Crear la estructura inicial del paquete usethis::create_package("mipaquete") Podemos agregar la estructura de biocthis biocthis::use_bioc_pkg_templates() Pedir que Git ignore el archivo .Rproj usethis::use_git_ignore("*.Rproj") Crear el respositorio de GitHub usethis::use_github() Crear el archivo Description estilo Bioconductor biocthis::use_bioc_description() Crear el archivo README estilo Bioconductor biocthis::use_bioc_readme_rmd() devtools::build_readme() Recuerda guardar los cambios, hacer commit y push. Crear el archivo NEWS estilo Bioconductor biocthis::use_bioc_news_md() Crear los archivos de ayuda para usuarios y contribuidores biocthis::use_bioc_coc() usethis::use_tidy_contributing() biocthis::use_bioc_support() biocthis::use_bioc_issue_template() biocthis::use_bioc_citation() 4.3 Checks 4.3.1 BiocCheck BiocManager::install("BiocCheck") BiocCheck::BiocCheck() Algunas reglas de BiocCheck: Utilizar el símbolo <- en lugar de = para definir funciones y variables. Utilizar TRUE y FALSE en lugar de T y F. Indentar el código usando 4 espacios. Las líneas de código y documentación no deben ser mayores a 80 caracteres. Las funciones deben tener 50 líneas de código o menos. El paquete debe contener al menos una viñeta. Al menos 80% de las funciones deben tener ejemplos reproducibles. Las dependencias deben ser declaradas en el archivo DESCRIPTION. El paquete debe tener al menos un biocView. El tamaño del paquete no debe ser mayor 5Mb. El maintainer debe estar suscrito a la lista de correo de Bioconductor. El maintainer debe agregar su paquete en los tags de Bioconductor. 4.3.2 rcmdcheck install.packages("rcmdcheck") rcmdcheck::rcmdcheck() Algunas reglas de rcmdcheck: El paquete debe ser instalable. Los ejemplos de las funciones deben ser reproducibles. Las viñetas deben ser reproducibles. Todas las unidades de prueba deben pasar sin errores. El archivo DESCRIPTON debe tener el formato adecuado. 4.4 Modificando el archivo DESCRIPTION Paquete Este es el nombre del paquete. El nombre del repositorio y el nombre del paquete en la descripción deben coincidir (incluyendo mayúsculas y minúsculas). Título Este es un título breve pero descriptivo para el paquete. Versión Todos los paquetes de Bioconductor utilizan un esquema de versión x.y.z. Cuando se envía por primera vez a Bioconductor, un paquete debe tener la versión 0.99.0. Se aplican las siguientes reglas: x es normalmente 0 para paquetes que aún no han sido liberados. y es par para paquetes liberados, e impar para paquetes en desarrollo. Generalmente, no se debe aumentar este número en el pre-release. z se incrementa siempre que se realizan cambios en el paquete. Descripción La descripción debe ser una visión general relativamente breve pero detallada de lo que implica la funcionalidad del paquete. Debe ser de al menos tres oraciones completas. Autores Se requiere una designación de maintainer (cre) con una dirección de correo electrónico que se mantenga activamente. Esta dirección de correo se utilizará para el contacto con respecto a cualquier problema que surja con el paquete en el futuro. Idealmente, se debe incluir el ORCiD por lo menos del maintainer. person("Lori", "Shepherd", email = Lori.Shepherd@roswellpark.org, role = c("cre", "aut"), comment = c(ORCID = "0000-0002-5910-4010")) Sólo debe figurar una persona como responsable para garantizar un único punto de contacto. Esta persona tendrá acceso al repositorio git en git.bioconductor.org. El acceso a Commit puede ser dado a otros desarrolladores por solicitud en la lista de correo bioc-devel. Otra opción es añadir colaboradores al repositorio de GitHub. Este enfoque permite el desarrollo por muchos pero restringe el acceso a git.bioconductor.org. Licencia El campo de licencia debe referirse preferentemente a una licencia estándar no restrictiva. Las licencias que restringen el uso, por ejemplo, a investigadores académicos o sin fines de lucro, no son adecuadas para Bioconductor. Los paquetes de bioconductor básico suelen estar licenciados bajo Artistic-2.0. El paquete debe contener sólo código que pueda ser redistribuido de acuerdo con la licencia del paquete. LazyData Para paquetes que incluyen datos, se recomienda NO incluir LazyData: TRUE. Incluirlo en ese caso, ralentiza la carga de paquetes con datos grandes. Dependencias Todos los paquetes deben estar disponibles a través de biocViews o CRAN de Bioconductor; el uso del campo Remotes: no es soportado, por lo tanto las dependencias sólo disponibles en otros repositorios (e.g. GitHub) no están permitidas. Un paquete puede ser listado sólo una vez entre Depends, Imports, Suggests, o Enhances: Imports: es para paquetes que proporcionan funciones, métodos o clases que se usan dentro del código del paquete. La mayoría de los paquetes están listados aquí. Depends: es para paquetes que proporcionan funcionalidad esencial para los usuarios del paquete, por ejemplo, el paquete GenomicRanges se enumera en el campo Depends: de GenomicAlignments. Es poco común que más de tres paquetes aparezcan como Depends:. Suggests: es para paquetes usados en viñetas, ejemplos y código condicional. Comúnmente, los paquetes de anotaciones y experimentos (por ejemplo, TxDb*) usados en viñetas y código de ejemplo se incluyen en este campo, evitando así una descarga costosa. Enhances: es para paquetes como parallel que mejoran el rendimiento del paquete, pero no son estrictamente necesarios para su funcionalidad. En el caso de que se requiera una función única externa para el código del paquete, la disponibilidad y el uso del paquete pueden hacerse a través de: if (!requireNamespace('suggPKG', quietly = TRUE)) stop("Install 'suggPKG' to use this function.") suggPKG::function() biocViews Este campo es obligatorio! Especifica al menos dos biocViews. Los términos deben provenir del mismo tipo de paquete (Software, AnnotationData, ExperimentData o Workflow). Puedes encontrar más información en: https://www.bioconductor.org/packages/release/BiocViews.html BugReports Se recomienda apuntar hacia el repositorio de GitHub, por ejemplo: https://github.com/usuario/paquete/issues. URL Se incluyen los links importantes, como el repositorio con el código fuente y el sitio web de pkgdown si se cuenta con él. Por ejemplo: https://github.com/usuario/paquete https://usuario.github.io/paquete 4.5 Modificando el archivo NEWS Secciones: New: Nuevas funciones. Bug fixes: Reparación de errores en las funciones previas o en la documentación. Changes: Cambios en el código de las funciones, incluyendo modificaciones en los argumentos. Breaking changes: Cambios importantes que romperían el código en caso de no ser atendidos, por ejemplo el uso de funciones o argumentos antiguos. Enhancements: Mejoras a las funciones existentes. Formato El archivo NEWS se ve similar a este ejemplo: "],["creando-mis-primeras-funciones.html", "5 Creando mis primeras funciones 5.1 Diapositivas 5.2 Nombre de la función 5.3 Estructura de la función 5.4 ¡Tu turno! 5.5 Argumentos 5.6 ¡Tu turno! 5.7 Indentación 5.8 Uso de espacios 5.9 Comentarios 5.10 Mensajes para el usuario", " 5 Creando mis primeras funciones Instructora: Joselyn Chávez 29 de octubre de 2024 5.1 Diapositivas 5.2 Nombre de la función Cortos pero descriptivos Recomendable: Separar las palabras con _ Establecer una palabra en común al inicio para familias de funciones use_bioc_citation() # es mejor que citation() bioc_cit() usebioccitation() useBiocCitation() use.bioc.citation() 5.3 Estructura de la función Indentar las líneas de código. Agregar comentarios para separar/describir las secciones importantes. Usar la sintaxis paquete::funcion() cuando hacemos llamado a funciones de otros paquetes. usethis::use_r("subset_heatmap") Generemos el código de manera regular. Simulemos una matriz con diversas mediciones y grafiquemos los datos en un heatmap. mi_matriz <- matrix(rnorm(100), nrow = 10) rownames(mi_matriz) <- paste0("medicion_",letters[1:10]) colnames(mi_matriz) <- paste0("grupo_",letters[1:10]) library(ComplexHeatmap) Heatmap(mi_matriz, cluster_columns = FALSE, heatmap_legend_param = list(title = "valores")) Escribamos una función que permita seleccionar algunos grupos de interés y genere el heatmap. No la mejor opción: library(ComplexHeatmap) subset_heatmap <- function(x,mediciones=NULL,grupos=NULL) { x_subset <- x[mediciones,grupos] Heatmap(mi_matriz, cluster_columns=FALSE, heatmap_legend_param=list(title="valores")) } Un poco mejor: library(ComplexHeatmap) subset_heatmap <- function(x, mediciones = NULL, grupos = NULL) { x_subset <- x[mediciones,grupos] Heatmap(mi_matriz, cluster_columns = FALSE, heatmap_legend_param = list(title = "valores")) } Mucho mejor: subset_heatmap <- function(x, mediciones = NULL, grupos = NULL) { # subset matrix x_subset <- x[mediciones, grupos] # plot heatmap ComplexHeatmap::Heatmap( x_subset, cluster_columns = FALSE, heatmap_legend_param = list(title = "valores")) } Ejecutemos la función: subset_heatmap( mi_matriz, mediciones = c("medicion_a", "medicion_b", "medicion_c"), grupos = c("grupo_d","grupo_e","grupo_f")) 5.4 ¡Tu turno! Escribe una función que: Filtre la matriz y mantenga sólo los valores por encima de cierto valor. Genere el heatmap filtrado. Recuerda seguir las recomendaciones para escribir funciones. 5.5 Argumentos Los argumentos deben tener un nombre descriptivo y bien documentado. No la mejor opción: subset_heatmap <- function(x, m, g) { # subset matrix x_subset <- x[mediciones, grupos] } Una mejor opción: subset_heatmap <- function(x, mediciones, grupos) { # subset matrix x_subset <- x[mediciones, grupos] # plot heatmap ComplexHeatmap::Heatmap( x_subset, cluster_columns = FALSE, heatmap_legend_param = list(title = "valores")) } Los argumentos generalmente deben tener valores default. subset_heatmap <- function(x, mediciones = NULL, grupos = NULL, return_plot = TRUE) { # subset matrix x_subset <- x[mediciones, grupos] # plot heatmap ComplexHeatmap::Heatmap( x_subset, cluster_columns = FALSE, heatmap_legend_param = list(title = "valores")) } Evalúa la validez de los argumentos subset_heatmap <- function(x, mediciones = NULL, grupos = NULL, return_plot = TRUE) { stopifnot(is.matrix(x)) # subset matrix x_subset <- x[mediciones, grupos] # plot heatmap heatmap <- ComplexHeatmap::Heatmap( x_subset, cluster_columns = FALSE, heatmap_legend_param = list(title = "valores")) if(return_plot == TRUE) {return(heatmap)} } Este código no debe funcionar: subset_heatmap( as.data.frame(mi_matriz), mediciones = c("medicion_a", "medicion_b", "medicion_c"), grupos = c("grupo_d","grupo_e","grupo_f")) Nota: Usa las funciones is() para evaluar la clase de los objects, no uses class() == ni class() !=. Proporciona pistas para entender los errores. subset_heatmap <- function(x, mediciones = NULL, grupos = NULL, return_plot = TRUE) { if(!is.matrix(x)) {stop("x debe ser una matriz")} # subset matrix x_subset <- x[mediciones, grupos] # plot heatmap heatmap <- ComplexHeatmap::Heatmap( x_subset, cluster_columns = FALSE, heatmap_legend_param = list(title = "valores")) if(return_plot == TRUE) {return(heatmap)} } Este código debe dar un error, más un mensaje de ayuda. subset_heatmap( as.data.frame(mi_matriz), mediciones = c("medicion_a", "medicion_b", "medicion_c"), grupos = c("grupo_d","grupo_e","grupo_f")) 5.6 ¡Tu turno! Agrega pasos de evaluación para los otros argumentos de la función. Incluye mensajes de ayuda cuando el formato de los argumentos no es el esperado. 5.7 Indentación Usa 4 espacios para indentar, evita los tabs. No uses líneas de más de 80 caracteres. 5.8 Uso de espacios Usa un espacio después de la coma: a, b, c. Usa espacio después de operadores binarios: a == b. 5.9 Comentarios Usa “##” para comenzar las líneas de comentarios. Los comentarios deben usarse como notas y documentación solamente. No dejes código comentado que no se va a usar. Evita los TODO’s comentados cuando vayas a publicar el paquete. 5.10 Mensajes para el usuario Si deseas imprimir mensajes para el usuario, como el progreso del análisis en la función o advertir sobre los valores de los argumentos, evita el uso de cat(), mejor usa: message() comunica mensajes diagnóstico, como el progreso de la función. message("Paso 1: completo") ## Paso 1: completo warning() comunica situaciones inusuales que pueden ser manejadas por tu código. warning("El número de elementos esperados es mayor a uno, se tomará el primer valor del vector") ## Warning: El número de elementos esperados es mayor a uno, ## se tomará el primer valor del vector stop() indica una condición errónea. stop("x debe ser numérico") "],["documentación-de-funciones.html", "6 Documentación de funciones 6.1 Diapositivas 6.2 Links importantes: 6.3 ¿Qué es la documentación de una función y por qué es importante? 6.4 Generacion de la documentacion con ayuda del paquete roxygen 6.5 Antes de empezar…✏️ 6.6 Generacion de un bloque de documentacion con ayuda del paquete roxygen. 6.7 Otros campos de la documentacion.", " 6 Documentación de funciones Instructor/a: 29 de octubre de 2024 6.1 Diapositivas 6.2 Links importantes: Esta lección está basada en algunos manuales sobre documentación: Una viñeta del cranproject El manual de paqutes de r En esta viñeta de cranproject 6.3 ¿Qué es la documentación de una función y por qué es importante? 🙇️ Es la información complementaria que el desarrollador escribe sobre una función y que se accede con ? seguido el nombre de una función actual de un paquete p.ej. ?unafuncion. 📁 La documentación se almacena como un archivo .Rd (“R documentation) en la carpeta man/. 🔎 La documentación usa una síntesis especial, que es distinta a la de r y que está ligeramente basada en LaTeX. 📄 Se puede renderizar como html, pdf o texto sin formato según se necesite. 6.4 Generacion de la documentacion con ayuda del paquete roxygen En un paquete de r y en cualquier ecosistema de devtools no editamos un documento .Rd manualmente. La documentación usa una síntesis parecida a LaTex que puede ser fácil de estropear. Por ventaja existen paquetes como roxigen2. Usar roxigen nos permite usar comentarios especiales sobre el inicio de la función, esto nos da un par de ventajas: ✅ La documentación y la función estarán en un mismo lugar, por lo que si editas la función será mas fácil recordar actualizar la documentcion también. 🎉 Puedes usar markdown en lugar de la síntesis especial para los archivos .Rd 6.5 Antes de empezar…✏️ Vamos a crear un función para nuestro paquete. Supongamos que para nuestro paquete necesitamos una función que calcule la moda. Esta es una forma sencilla de calcular la moda: getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } unique(serievector): Crea un vector que contiene únicamente los valores únicos de la serie de números serievector. match(serievector, uniqv): Encuentra la posición de cada valor de serievector en el vector único uniqv. tabulate(match(serievector, uniqv)): Cuenta cuántas veces aparece cada valor en la serie serievector. which.max(tabulate(match(serievector, uniqv))): Encuentra el índice del valor máximo en el vector de frecuencias. uniqv[which.max(tabulate(match(serievector, uniqv)))]: Devuelve el valor correspondiente al índice calculado, que es la moda. Creamos un ejemplo para ver que funcione: serie_numeros <- c(1, 2, 2, 2, 2, 3, 3, 4, 4, 4) resultado <- getmode(serie_numeros) print(resultado) ## [1] 2 Bien ahora si podemos podemos empezar a usar el paquete de roxygen para documentar nuestra función.. comencemos. 6.6 Generacion de un bloque de documentacion con ayuda del paquete roxygen. Podemos insertar un esqueleto de comentarios de roxygen para ver su síntesis. Colocamos el cursor en algún lugar de la definición de nuestra función y buscamos en la pestaña Código > Insertar Roxygen Skeleton. #' Title #' #' @param serievector #' #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Ahora ya tenemos un esqueleto de la documentación que nos da una ventaja para su creación. Las líneas de comentarios de Roxygen siempre comienzan con #', el habitual para un comentario # mas un ' Veamos los comentarios de uno por uno: Empezamos con el titulo. Se sugiere poner en el titulo las acciones principales que realiza la función en este caso por ejemplo podremos usar: #' @title Encontrar la Moda de una Serie de Números #' #' @param serievector #' #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Muy bien!. El siguiente comentario que podemos ver es @param. Pero antes, vamos a añadir una pequeña descripción de la función y como usarla. Primero añadimos la pequeña descripción con @description: #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' @param serievector #' #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Ahora vamos a añadir el comentario @usage que nos indica como puedes mandar a llamar la función. #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' @usage getmode(serievector) #' @param serievector #' #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Ahora si vamos a añadir una pequeña descripción de nuestros argumentos. Si tuviéramos mas de un parámetro en nuestra función podríamos llamar las veces que sea necesario el comentario de parámetro con @param, veamoslo. Ahora añadimos una pequeña descripción a nuestro único parámetro que es serievector: #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' #' @param serievector Es una serie de números en forma de un vector simple de r. #' #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Después, podemos añadir un comentario de detalles de la función con @details. Por ejemplo, si en nuestro ejemplo tuviéramos ciertos valores no numéricos en nuestro vector de entrada, por ejemplo letras, ¿nuestra función podría leerlas?, o si le diéramos un vector sin caracteres ¿que pasaría?, veamos: serie_numeros <- c(0,2,2,"d", "d","d") resultado <- getmode(serie_numeros) print(resultado) ## [1] "d" serie_numeros <- c() resultado <- getmode(serie_numeros) print(resultado) ## NULL Entonces, esto es un ejemplo de lo que podríamos poner en el comentario @details. Hagamoslo describiendo esto. En details podemos agregar detalles un poco mas específicos que en la descripción de la función #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' #' @param serievector Es una serie de números en forma de un vector simple de r. #' #' @details si tu vector de entrada puede ser interpretado alternando números y #' letras escritas entre comillas "". Si un vector esta vacío, dará como #' resultado un NULL. #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Ya casi terminamos de llenar nuestra documentación, pero antes vamos a ver algunos otros arrobas que pudieran ser importantes. El @import e @importfrom importan funciones de otros paquetes en caso de que las necesitemos, el primero importa todas las funciones del paquete que que solicites, y el segundo importa solo algunas funciones especificas. En nuestra función no necesitamos llamar funciones de otros paquetes puesto que todas las que usamos están en r base. Pero imaginemos que tu función, por ejemplo necesita leer un archivo .tsv con la función read_tsv del paquete readr y después reconvertir la tabla resultante en un archivo con write.table pero solo necesitas esa función del paquete utils, entonces haríamos: #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' #' @param serievector Es una serie de números en forma de un vector simple de r. #' #' @details si tu vector de entrada puede ser interpretado alternando números y #' letras escritas entre comillas "". Si un vector esta vacío, dará como #' resultado un NULL. #' @import readr #' @importFrom utils write.table #' @return #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Así podemos importar las funciones que necesitemos de otros paquetes y se incluirán en la documentación y se cargaran automáticamente al cargar tu paquete. :eyes::exclamation: Para un correcto funcionamiento de tu paquete y al estar los paquetes necesarios incluidos en la documentación, no será necesario llamarlos de la forma ``library(“apackage”)```. Entonces llegamos a la sección @return. Esta descripción le servirá al usuario del paquete para conocer cual sera el resultado de la función, que puede ser un archivo, una tabla, un numero,etc. Entonces retomando la función que usamos al inicio, vamos a escribir una descripción corta del resultado de la función getmode(). #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' #' @param serievector Es una serie de números en forma de un vector simple de r. #' #' @details si tu vector de entrada puede ser interpretado alternando números y #' letras escritas entre comillas "". Si un vector esta vacío, dará como #' resultado un NULL. #' @return El carácter con mas frecuencia de el vector de entrada. #' @export #' #' @examples getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Por ultimo tenemos @export que es el encargado de renderizar la documentación para que pueda aparecer en la ventana de Ayuda (abajo a la derecha). esta opción la dejamos para funciones principales que el usuario va a utilizar, aunque puede que existan alguna funciones internas que no queremos que el usuario vea. En ese caso vamos a usar @noRd en lugar de este. Antes de terminar podemos incluir ejemplos de como funciona nuestra función para un mejor entendimiento, pongamos los que ya realizamos: #' @title Encontrar la Moda de una Serie de Números #' #' @description Esta función lee una serie de números en forma de vector y #' encuentra el elemento que mas se repite, es decir la moda. #' #' @param serievector Es una serie de números en forma de un vector simple de r. #' #' @details si tu vector de entrada puede ser interpretado alternando números y #' letras escritas entre comillas "". Si un vector esta vacío, dará como #' resultado un NULL. #' @return El carácter con mas frecuencia de el vector de entrada. #' @export #' #' @examples #' serie_números <- c(1, 2, 2, 2, 2, 3, 3, 4, 4, 4) #' resultado <- getmode(serie_números) #' print(resultado) getmode <- function(serievector) { uniqv <- unique(serievector) uniqv[which.max(tabulate(match(serievector, uniqv)))] } Ahora si, una vez teniendo listo el bloque de comentarios para la documentación, vamos a ejecutar devtools::load_all() para cargar nuestras funciones y hecho esto, ejecutamos devtools::document() o presionamos Ctrl/Cmd + Shift + D para convertir los comentarios en archivo .Rd y poder renderizarlo. 💯 Listo, tenemos nuestra documentación para una función. Así se verá cuando el paquete esté terminado. 6.7 Otros campos de la documentacion. @seealso para indicar funciones relacionadas y facilitar la búsqueda de funciones. @references añade algunas referencias. @author para especificar el autor de la función. "],["diseño-de-pruebas.html", "7 Diseño de pruebas 7.1 Diapositivas", " 7 Diseño de pruebas Mirna Vázquez Rosas-Landa 30 de octubre de 2024 7.1 Diapositivas "],["creación-de-viñetas.html", "8 Creación de viñetas 8.1 Diapositivas 8.2 ¿Qué es una viñeta? 8.3 Características de una vignette 8.4 ¿Cómo consultar la viñeta de un paquete? 8.5 ¿Cómo crear una viñeta? 8.6 ¿Cómo guardar y actualizar la viñeta? 8.7 Veamos un ejemplo 8.8 Actividad", " 8 Creación de viñetas José Antonio Ovando Ricárdez 30 de octubre de 2024 8.1 Diapositivas 8.2 ¿Qué es una viñeta? Es una guía extendida sobre cómo funciona el paquete. Es recomendable que muestre cómo utilizar las funciones del paquete, aplicado en un flujo de trabajo; por ejemplo: el análisis estadístico de una encuesta o el análisis de expresión diferencial de genes. Podemos estructurarlo como haríamos con la escritura de un capítulo de libro o de un artículo científico: debe mostrar el problema a resolver y la metodología paso a paso sobre cómo el paquete lo resuelve. Si el paquete contiene funciones que se complementan entre sí para alcanzar un fin específico, entonces debes mostrar su uso de forma compartamentalizada. 8.3 Características de una vignette Debe mostrar un flujo de análisis explotando el potencial de tu paquete. Implementa tantas funciones de tu paquete como sea posible, pero no es necesario que incluya todas. Los datos a usar deben ser pequeños o fáciles de acceder. Puedes crear múltiples viñetas para mostrar diferentes casos de análisis y cubrir una mayor cantidad de funciones. 8.4 ¿Cómo consultar la viñeta de un paquete? browseVignettes(package = "ggplot2") 8.5 ¿Cómo crear una viñeta? biocthis::use_bioc_vignette("mi_vignette") Esta función tendrá tres efectos: Generar el directorio vignettes en caso que no exista. Agregar dependencias en el archivo DESCRIPTION (por ejemplo, knitr necesario para construir viñetas dentro del paquete). Abrir un templado en formato .Rmd para comenzar a escribir la viñeta, que se va a guardar en vignettes/mi_vignette.Rmd 8.6 ¿Cómo guardar y actualizar la viñeta? Una vez que se ha generado el archivo vignettes/mi_vignette.Rmd se hacen las modificaciones necesarias. Puedes usar el comando: edit_file("vignettes/mi_vignette.Rmd") Para guardar los cambios debes hacer click en el botón Knit o utiliza la combinación de teclas Ctrl/Cmd-Shift-K. 8.7 Veamos un ejemplo Busca la viñeta del paquete regutools en la página de Bioconductor https://bioconductor.org/packages/release/bioc/html/regutools.html 8.8 Actividad Escribe una viñeta que muestre cómo utilizar las funciones para cargar y filtrar los datos de pbmc. "],["compilación-e-instalación-de-paquetes.html", "9 Compilación e instalación de paquetes 9.1 Diapositivas 9.2 Metadatos de una paquetería 9.3 Licencias 9.4 Paqueterías de código fuente 9.5 ¿En dónde podemos encontrar el código fuente de un paquete? 9.6 Instalando la última versión en desarrollo 9.7 Instalando paquetes desde GitHub 9.8 Instalando un paquete local 9.9 Contribuyendo código", " 9 Compilación e instalación de paquetes Joselyn Cristina Chávez Fuentes 30 de octubre de 2024 9.1 Diapositivas 9.2 Metadatos de una paquetería Los metadatos de la paquetería se encuentran en el archivo DESCRIPTION. 9.2.1 Description El campo Description describe lo que hace tu paquetería. Suele ser extenso, si requieres escribir múltiples líneas, deben estar indentadas. Por ejemplo: # Description: Este paquete contiene todas las funciones generadas en el curso # de escritura de paqueterías en R. También contiene las funciones que cada # participante propuso para solucionar un problema relacionado con su trabajo. 9.2.2 Dependencias Las dependencias son las paqueterías que tu paquete necesita para funcionar. La lista de paquetes se escribe separada por comas y es recomendado que se escriban en orden alfabético. Existen tres tipos: Imports: Son paquetes que deben instalarse para que tu paquete funcione y por tanto se van a instalar en el momento que instales el paquete. Internamente existe una función que evalúa si los paquetes se encuentran instalados o no y solamente instala los faltantes. Esta dependencia hace solamente la instalación pero no ejecuta library(), por lo que los paquetes requeridos deberán ser cargados dentro de la escritura del paquete. Depends: Son paquetes que obligatoriamente deben estar para que tu paquetería funcione pero no se instalarán de manera automática. Aquí también se indica la versión de R requerida para el funcionamiento del paquete. Los paquetes que se listen aquí se van a cargar al mismo tiempo que se ejecute el library(mipaquete). Suggests: Se refiere a los paquetes que tu paquete puede utilizar y aprovechar para ser más poderoso en el análsis pero no los necesita para funcionar. Por ejemplo, paquetes que contienen sets de datos para hacer pruebas o análisis de práctica. Nota Importante Se recomienda listar los paquetes necesarios para el funcionamiento de nuestro paquete en Imports porque cuando se ponen en Depends se cargan los paquetes completos y probablemente solamente requerimos una o dos funciones. Cargar demasiados paquetes completos, sin ser necesario, sólo hace que nuestro paquete se vuelva pesado y lento. Es mejor llamar particularmente a las funciones usando la sintaxis explícita: Biostrings::translate() 9.2.3 ¿Cómo añadir dependencias? Usando usethis: usethis::use_package("ggplot2", type = "Imports") Editando manualmente el archivo DESCRIPTION. 9.3 Licencias Establece quién puede usar tu paquete. Existen diversas licencias pero hablaremos sobre las 3 más comunes: MIT (Massachusetts Institute of Technology): es simple y permisiva. Permite a cualquier persona usar y distribuir tu paquetería con una sola restricción: la distribución debe incluir la declaración de licencia del autor. Existe un texto base al cual se le pueden añadir cláusulas o excepciones. Este es un ejemplo: GPL-2 (General Public License): Permite usar y distribuir tu código con la condición que si se genera una versión modificada de tu código, su distribución debe ser también bajo esta licencia. Aunque está enfocada a la distribución de código abierto, permite dejar en claro quién es el autor del material y evitar la apropiación del código por terceros. Un ejemplo de la aplicación de esta licencia es el desarrollo de Linux. CCO: Esta licencia implica que cedes todos los derechos y el código puede ser utilizado con cualquier fin, excepto fines comerciales. Es el más utilizado en los paquetes. Concede el derecho a utilizar y distribuir el material sin requerir el permiso del autor. 9.4 Paqueterías de código fuente En algunas ocasiones necesitaremos instalar paquetes que no se encuentran compilados, por ejemplo: Paquetes en desarrollo de CRAN o Bioconductor. Versiones anteriores de paquetes de CRAN o Bioconductor. Paquetes que no se encuentran depositados en CRAN o Bioconductor, sino en repositorios personales como GitHub. Paquetes que estás desarrollando de forma local. El paquete remotes será de gran utilidad. Regularmente, los paquetes que instalamos desde algún repositorio como CRAN o Bioconductor son paquetes binarios que ya se encuentran compilados previamente. Existen algunas funciones que nos permiten instalar paquetes desde código fuente. Anteriormente, se solían utilizar las funciones install_* del paquete devtools; sin embargo, recientemente se creó el paquete remotes que contiene las mismas funciones pero está específicamente diseñado para ayudarnos a trabajar con paquetes desde código fuente. 9.5 ¿En dónde podemos encontrar el código fuente de un paquete? Si el paquete se encuentra disponible en CRAN, puedes encontrar el link al código fuente en la sección URL. Si el paquete se encuentra disponible en Bioconductor, puedes encontrar el link al código fuente en la sección Package Archives Si el paquete se encuentra en GitHub o GitLab, necesitarás conocer el nombre de usuario y el nombre del paquete. 9.6 Instalando la última versión en desarrollo Si el paquete se encuentra depositado en CRAN podemos usar la función remotes::install_dev("pkgname") Por ejemplo, para instalar la versión en desarrollo de dplyr usaremos el comando remotes::install_dev("dplyr") Si el paquete se encuentra en Bioconductor usaremos la siguiente función: remotes::install_bioc("pkgname") Por ejemplo, para instalar la versión en desarrollo de regutools, el paquete desarrollado por miembros de la CDSB, usaremos el comando remotes::install_bioc("regutools") 9.7 Instalando paquetes desde GitHub Para poder instalar un paquete desde GitHub necesitaremos conocer el usuario del creador y el nombre del repositorio. remotes::install_github("usuario/repositorio") Por ejemplo, para instalar el paquete starwarssay desarrollado por Erick Cuevas (Erickcufe) utilizaremos el siguiente comando: remotes::install_github("Erickcufe/starwarssay") Independientemente de si el paquete se encuentra en CRAN, Bioconductor, o ninguno de ellos, podemos instalar un paquete depositado en una cuenta de GitHub. Para poder instalar un paquete desde GitHub necesitaremos conocer el usuario del creador y el nombre del repositorio donde se encuentra depositado el paquete. Con esta información usaremos la siguiente función: 9.8 Instalando un paquete local Paso 1: Abre el proyecto del paquete que estás desarrollando. Paso opcional: Ejecuta la documentación si realizaste algún cambio. devtools::document() Paso 2: Construye el paquete: devtools::build() Paso 3: Instala el paquete desde tu proyecto actual: devtools::install() 9.9 Contribuyendo código Una ventaja de descargar el paquete de forma local es que puedes realizar cambios, probar que funciona de manera local y después contribuir (haciendo un pull-request). Usemos el paquete saludo Clona el repositorio en tu computadora. git clone https://github.com/ComunidadBioInfo/saludo.git Ahora puedes abrir el proyecto del paquete y agregar tu código. "],["creación-de-sitios-web-con-pkgdown.html", "10 Creación de sitios web con pkgdown 10.1 Diapositivas 10.2 Instalación 10.3 Configura el paquete para crear el sitio con pkgdown 10.4 Genera la estructura de pkgdown 10.5 Pre-visualiza el sitio de manera local 10.6 Personalizando el _pkgdown.yml 10.7 Las variables bslib 10.8 Layout 10.9 Accessibilidad 10.10 La página de inicio 10.11 La página de referencias 10.12 Articles 10.13 News 10.14 Publicando el sitio web", " 10 Creación de sitios web con pkgdown Joselyn Cristina Chávez Fuentes 31 de octubre de 2024 10.1 Diapositivas div.grey { background-color: #bfbfbf; } div.center { text-align:center; } 10.2 Instalación install.packages("pkgdown") 10.3 Configura el paquete para crear el sitio con pkgdown Este paso se ejecuta solamente una vez, dentro del proyecto del paquete. usethis::use_pkgdown_github_pages() Este paso genera las acciones automáticas de GitHub para renderizar el sitio. El archivo README.md será tu página de inicio, la documentación en man/ va a crear una sección de referencias, y las viñetas serán renderizadas como articles. 10.4 Genera la estructura de pkgdown Este paso se ejecuta solamente una vez. usethis::use_pkgdown() 10.5 Pre-visualiza el sitio de manera local Este paso lo puedes ejecutar para visualizar el sitio cada vez que hagas una modificación, antes de enviar los cambios a GitHub. pkgdown::build_site() 10.6 Personalizando el _pkgdown.yml 10.6.1 Metadatos URL Este es el link donde se va a renderizar el sitio, revisa que sea correcto y, de ser necesario, actualízalo. url: https://pkgdown.r-lib.org template Esta sección permite personalizar la apariencia general del sitio. template: bootstrap: 5 bootswatch: cerulean 10.6.2 Temas Light switch Puedes proporcionar un “light switch” para permitir a tus usuarios cambiar entre temas oscuros y claros configurando la opción de light-switch a true: template: light-switch: true Bootswatch themes La forma más fácil de cambiar toda la apariencia de tu sitio web es usar un tema de Bootswatch: template: bootstrap: 5 bootswatch: materia Puedes ver los temas disponibles en https://bootswatch.com/ Estos temas suelen no ser compatibles con el light switch, pero puedes intentar. Al cambiar el bootswatch theme necesitas renderizar el sitio para ver por completo los efectos del tema. build_site() Mientras estás experimentando, puedes acelerar las cosas simplemente reconstruyendo la página de inicio y el CSS ejecutando: build_home_index() init_site() y luego actualizando el navegador. Los bootswatch theme con barras de navegación altas (lux, pulse) también requieren que se modifique la variable pkgdown-nav-height. Debido a que los temas de bootswatch son proporcionados por el paquete bslib, se puede anidar el campo bootswatch debajo del campo bslib. template: bootstrap: 5 bslib: bootswatch: lux pkgdown-nav-height: 100px 10.7 Las variables bslib Hay tres variables clave que afectan al color: bg (fondo) determina el fondo de la página. fg (primer plano) determina el color del texto. primary establece el color del enlace y el color translúcido en la barra de navegación y la barra lateral. template: bootstrap: 5 bslib: bg: "#202123" fg: "#B8BCC2" primary: "#306cc9" También se pueden personalizar las fuentes predeterminadas utilizadas para la mayoría del texto (base_font), para los encabezados (heading_font) y para el código (code_font). La forma más fácil es proporcionar el nombre de una fuente de Google con la siguiente sintaxis: template: bootstrap: 5 bslib: base_font: {google: "Roboto"} heading_font: {google: "Roboto Slab"} code_font: {google: "JetBrains Mono"} 10.7.1 Syntax highlighting Los colores utilizados para el resaltado de sintaxis en bloques de código están controlados por la configuración theme: template: bootstrap: 5 theme: breeze-light Puedes elegir entre: a11y-dark, a11y-light, arrow-dark, arrow-light, atom-one-dark, atom-one-light, ayu-dark, ayu-light, ayu-mirage, breeze-dark, breeze-light, breezedark, dracula, espresso, github-dark, github-light, gruvbox-dark, gruvbox-light, haddock, kate, monochrome-dark, monochrome-light, monochrome, monokai, nord, oblivion, printing, pygments, radical, solarized-dark, solarized-light, solarized, tango, vim-dark, zenburn. 10.7.2 Navbar style Los campos bg y type de la barra de navegación controlan los colores del fondo y el primer plano respectivamente. Normalmente bg será light, dark, o primary: navbar: bg: primary 10.8 Layout Puedes personalizar el contenido de la barra de navegación, pie de página, utilizando los campos navbar y footer. Todos ellos utilizan una estructura similar que define por separado la estructura global y los componentes individuales. 10.8.1 Navbar Esta es la estructura default: navbar: structure: left: [intro, reference, articles, tutorials, news] right: [search, github, lightswitch] intro: “Get Started”, enlaza a una viñeta o artículo con el mismo nombre que el paquete. reference: si hay archivos . Rd. articles: si hay viñetas o artículos. tutorials: si hay algún tutorial. news: si existe NEWS.md. search: la barra de búsqueda. github: un enlace al repositorio de origen (con un icono), es determinado automáticamente a partir del archivo DESCRIPTION. lightswitch; un “interruptor de luz” para seleccionar el modo claro, modo oscuro o modo automático. Puedes utilizar el campo structure para reorganizar la barra de navegación: navbar: structure: left: [search] right: [reference, articles] Puedes usar la misma sintaxis para organizar el menú de artículos: navbar: components: articles: text: Articles menu: - text: Category A - text: Title A1 href: articles/a1.html - text: Title A2 href: articles/a2.html - text: ------- - text: "Category B" - text: Article B1 href: articles/b1.html 10.8.2 Footer Esta es la estructura por defecto:: footer: structure: left: developed_by right: built_with Que utiliza dos de los tres componentes incorporados: developed_by: una frase que describe a los principales autores del paquete. built_with: una frase que hace publicidad de la misma. package: el nombre del paquete. Puedes personalizar la organización del pie de página: footer: structure: left: pkgdown right: [developed_by, legal] components: legal: Provided without **any warranty**. 10.9 Accessibilidad Las configuraciones default de pkgdown tratan de hacer el sitio lo más accesible posible para todos, pero hay algunos puntos a tomar en cuenta: 10.9.1 Colores Si ajustas cualquier color del tema default, verifica que el contraste entre el fondo y el primer plano no haga difícil leer ningún texto. Puedes utilizar la herramienta de evaluación de accessibilidad en https://wave.webaim.org. El color default genera un contraste demasiado bajo contra el fondo gris pálido de la barra de navegación. Este color viene de la paleta “danger” de bootstrap, así que puedes arreglarlo sobreescribiendo esa variable en tu _pkgdown.yml: template: bootstrap: 5 bslib: danger: "#A6081A" Si utilizas entradas de barra de navegación personalizadas que sólo muestran un icono, asegúrate de utilizar también el campo aria-label para proporcionar una etiqueta accesible que describa el icono. cran: icon: fab fa-r-project href: https://cloud.r-project.org/package=pkgdown aria-label: View on CRAN 10.9.2 Imágenes Para hacer tu sitio completamente accessible, agrega una descripción del contenido de las imágenes en las viñetas usando el campo “fig.alt” de las opciones del chunk de R. 10.10 La página de inicio Los contenidos del home page son automáticamente generados desde el archivo index.md o el README.md. pkgdown les asigna diferentes prioridades, por lo que es possible tener contenidos diferentes en el repositorio de GitHub y la página de pkgdown si provees ambos archivos. La página de inicio también incluye una barra de contenidos con links importantes, como la guía de contribución, el código de conducta, etc. 10.11 La página de referencias pkgdown crea una página de referencia en reference/ para cada una de las funciones del paquete, basado en la documentación. pkgdown ejecuta todos los ejemplos de las funciones, insertando los resultados renderizados en los archivos HTML generados. Por defecto, pkgdown genera un índice de referencia que es sólo una lista de funciones ordenadas alfabéticamente. El índice es mucho más útil con la curación manual porque las funciones pueden agruparse y describirse en categorías. Cada entrada de referencia puede adoptar una de las tres formas siguientes: Un título, definido por los campos title y desc (descripción) opcionales. Un subtítulo, definido por los campos de subtítulo y desc (descripción) opcionales. Lista de temas definidos por un campo de contenido. Mientras editas el índice de referencias, puedes ejecuar la siguiente función para renderizar solamente el índice, lo que permite ver de forma rápida el efecto de los cambios sin tener que renderizar todo el sitio. pkgdown::build_reference_index() reference: - title: "Connecting to Spark" desc: > Functions for installing Spark components and managing connections to Spark contents: - spark_config - spark_connect - spark_disconnect - spark_install - spark_log 10.12 Articles pkgdown creará automáticamente todas las viñetas que se encuentran en la carpeta vignettes/, traduciéndolas a archivos HTML en articles/. Se puede nombrar el artículo de introducción con el nombre del paquete para generar una página “Get Started” automáticamente. 10.13 News Si el archivo NEWS.md está presente, se procesará en un changelog de una sola página basado en los títulos de las secciones del archivo. pkgdown asume que el archivo NEWS.md está formateado con encabezados de nivel uno (#) para especificar el nombre del paquete y el número de versión, y con encabezados de nivel dos (##) para proporcionar una organización temática para cada versión. # pkgdown 1.1.0 ## Bug Fixes * Lots of them 10.14 Publicando el sitio web Haz commit de los cambios y luego push. Ve al repositorio del paquete en GitHub y espera a que la acción de GitHub termine de renderizar el sitio. Ve al sitio web, el formato debe ser similar a https://usuario.github.io/paquete "],["proyectos-colaborativos-1.html", "11 Proyectos colaborativos 11.1 Propuesta 1 11.2 Propuesta 2 11.3 Propuesta 3 11.4 Propuesta 4 11.5 Propuesta 5", " 11 Proyectos colaborativos 11.1 Propuesta 1 11.2 Propuesta 2 11.3 Propuesta 3 11.4 Propuesta 4 11.5 Propuesta 5 "],["404.html", "Page not found", " Page not found The page you requested cannot be found (perhaps it was moved or renamed). You may want to try searching to find the page's new location, or use the table of contents to find the page you are looking for. "]] diff --git "a/docs/soluci\303\263n-de-problemas-con-las-versiones-de-paquetes-de-rstudio.html" "b/docs/soluci\303\263n-de-problemas-con-las-versiones-de-paquetes-de-rstudio.html" index 98fa408..392ceaf 100644 --- "a/docs/soluci\303\263n-de-problemas-con-las-versiones-de-paquetes-de-rstudio.html" +++ "b/docs/soluci\303\263n-de-problemas-con-las-versiones-de-paquetes-de-rstudio.html" @@ -217,6 +217,15 @@
              • 5 Creando mis primeras funciones
              • 6 Documentación de funciones