From 53b6683f8ac5a19c843a424ce20c3755e263eef6 Mon Sep 17 00:00:00 2001 From: James Hollway Date: Wed, 6 Nov 2024 17:23:00 +0100 Subject: [PATCH 1/9] Updated pushrelease --- .github/workflows/pushrelease.yml | 24 ++++++++---------------- 1 file changed, 8 insertions(+), 16 deletions(-) diff --git a/.github/workflows/pushrelease.yml b/.github/workflows/pushrelease.yml index 6aefb662..d6f8cef2 100644 --- a/.github/workflows/pushrelease.yml +++ b/.github/workflows/pushrelease.yml @@ -85,24 +85,16 @@ jobs: DEFAULT_BUMP: patch RELEASE_BRANCHES: main - name: Checkout two - uses: actions/checkout@v2 - - name: Create Release - id: create_release - uses: actions/create-release@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - tag_name: ${{ steps.newtag.outputs.tag }} - release_name: Release ${{ steps.newtag.outputs.tag }} - draft: false - prerelease: false + uses: actions/checkout@v4 + + - name: Extract version + run: | + echo "PACKAGE_VERSION=$(grep '^Version' DESCRIPTION | sed 's/.*: *//')" >> $GITHUB_ENV + echo "PACKAGE_NAME=$(grep '^Package' DESCRIPTION | sed 's/.*: *//')" >> $GITHUB_ENV - name: Download binaries uses: actions/download-artifact@v4 - - name: Display structure of downloaded files - run: ls -R - - name: Rename binaries release shell: bash run: | @@ -112,7 +104,7 @@ jobs: cp ./winOS/${{ env.PACKAGE_NAME }}_${{ env.PACKAGE_VERSION }}*.zip . echo "Renamed files" ls migraph_* - + - name: Create Release and Upload Assets id: create_release uses: softprops/action-gh-release@v2 @@ -128,7 +120,7 @@ jobs: migraph_*.tar.gz migraph_*.zip env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} pkgdown: name: Build and deploy website From 1b98d79de93cbd0ec5cc12124508791d46b58114 Mon Sep 17 00:00:00 2001 From: James Hollway Date: Fri, 29 Nov 2024 18:10:18 +0100 Subject: [PATCH 2/9] net_regression() now works without specifying tie weights --- R/model_regression.R | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/R/model_regression.R b/R/model_regression.R index 0ba0109e..2caa9403 100644 --- a/R/model_regression.R +++ b/R/model_regression.R @@ -422,8 +422,12 @@ convertToMatrixList <- function(formula, data){ } }}) IVs <- purrr::flatten(IVs) + names(IVs) <- vapply(IVs, function(x) attr(x, "names")[1], FUN.VALUE = character(1)) out <- c(list(DV), list(matrix(1, dim(DV)[1], dim(DV)[2])), IVs) - names(out)[1:2] <- c(formula[[2]], "(intercept)") + # Getting the names right + DVname <- formula[[2]] + if(DVname == ".") DVname <- "ties" + names(out)[1:2] <- c(DVname, "(intercept)") out } From 217e96574c8420dbaf32c5422b0f817f6ff75418 Mon Sep 17 00:00:00 2001 From: James Hollway Date: Fri, 29 Nov 2024 18:10:29 +0100 Subject: [PATCH 3/9] Renamed rproj --- migraphDev.Rproj => devmigraph.Rproj | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename migraphDev.Rproj => devmigraph.Rproj (100%) diff --git a/migraphDev.Rproj b/devmigraph.Rproj similarity index 100% rename from migraphDev.Rproj rename to devmigraph.Rproj From 5c008ed3c8815cfa2e25d43c08a6c7ce4f25ed30 Mon Sep 17 00:00:00 2001 From: James Hollway Date: Fri, 29 Nov 2024 18:11:11 +0100 Subject: [PATCH 4/9] Added print methods for netlm and netlogit, printing both tidy and glance --- NAMESPACE | 2 ++ R/class_models.R | 16 ++++++++++++++++ 2 files changed, 18 insertions(+) diff --git a/NAMESPACE b/NAMESPACE index 3a7158af..4c6e4e68 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -5,6 +5,8 @@ S3method(glance,netlogit) S3method(plot,netlm) S3method(plot,netlogit) S3method(plot,network_test) +S3method(print,netlm) +S3method(print,netlogit) S3method(print,network_test) S3method(tidy,netlm) S3method(tidy,netlogit) diff --git a/R/class_models.R b/R/class_models.R index a8e24562..ecd63522 100644 --- a/R/class_models.R +++ b/R/class_models.R @@ -132,6 +132,22 @@ glance.netlogit <- function(x, ...) { ) } +#' @export +print.netlm <- function(x, ...){ + cat("# Fitted model results\n") + print(tidy(x)) + cat("\n# Model summary statistics\n") + print(glance(x)) +} + +#' @export +print.netlogit <- function(x, ...){ + cat("# Fitted model results\n") + print(tidy(x)) + cat("\n# Model summary statistics\n") + print(glance(x)) +} + #' @export plot.netlm <- function(x, ...){ distrib <- x$dist From 8221df96582ebbeda16f7dadd559e7fcff3d4404 Mon Sep 17 00:00:00 2001 From: James Hollway Date: Sat, 30 Nov 2024 12:43:08 +0100 Subject: [PATCH 5/9] Fixed effect naming error --- R/model_regression.R | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/R/model_regression.R b/R/model_regression.R index 2caa9403..c5fdea12 100644 --- a/R/model_regression.R +++ b/R/model_regression.R @@ -417,12 +417,14 @@ convertToMatrixList <- function(formula, data){ out } else { if(is.list(out[[1]])) - out[[1]] else{ - list(out[[1]]) + out[[1]] else { + out <- list(out[[1]]) + names(out) <- attr(out[[1]], "names")[1] + attr(out[[1]], "names") <- NULL + out } }}) IVs <- purrr::flatten(IVs) - names(IVs) <- vapply(IVs, function(x) attr(x, "names")[1], FUN.VALUE = character(1)) out <- c(list(DV), list(matrix(1, dim(DV)[1], dim(DV)[2])), IVs) # Getting the names right DVname <- formula[[2]] From 154d6c0bc458a69f69a73368a2f56729f44a5b86 Mon Sep 17 00:00:00 2001 From: James Hollway Date: Sat, 30 Nov 2024 12:43:25 +0100 Subject: [PATCH 6/9] Specification advice updated for two-mode networks --- R/model_regression.R | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/R/model_regression.R b/R/model_regression.R index c5fdea12..c3f052d4 100644 --- a/R/model_regression.R +++ b/R/model_regression.R @@ -457,7 +457,9 @@ specificationAdvice <- function(formula, data){ vars <- formdf[formdf[,1] %in% c("sim","same"), 2] suggests <- vapply(vars, function(x){ incl <- unname(formdf[formdf[,2]==x, 1]) - excl <- setdiff(c("ego","alter"), incl) + if(manynet::is_twomode(data)){ + excl <- setdiff(c("ego","tertius"), incl) + } else excl <- setdiff(c("ego","alter"), incl) if(length(excl)>0) paste0(excl, "(", x, ")", collapse = ", ") else NA_character_ # incl }, FUN.VALUE = character(1)) @@ -466,8 +468,8 @@ specificationAdvice <- function(formula, data){ if(length(suggests)>0){ if(length(suggests) > 1) suggests <- paste0(suggests, collapse = ", ") - warning(paste("When testing for homophily,", - "it is recommended to include also more fundamental effects such as `ego()` and `alter()`.", + cat(paste("When testing for homophily,", + "it is recommended to include all more fundamental effects.\n", "Try adding", suggests, "to the model specification.")) } } From 374c4b1385edffae0d411d1ca18e4df767e8ffa7 Mon Sep 17 00:00:00 2001 From: James Hollway Date: Sat, 30 Nov 2024 12:43:41 +0100 Subject: [PATCH 7/9] same() now works for two-mode networks --- R/model_regression.R | 33 ++++++++++++++++++++++++++------- 1 file changed, 26 insertions(+), 7 deletions(-) diff --git a/R/model_regression.R b/R/model_regression.R index c3f052d4..2e720a01 100644 --- a/R/model_regression.R +++ b/R/model_regression.R @@ -287,8 +287,8 @@ vectorise_list <- function(glist, simplex, directed){ function(x) c(x))))) } -convertToMatrixList <- function(formula, data){ - data <- manynet::as_tidygraph(data) +convertToMatrixList <- function(formula, .data){ + data <- manynet::as_tidygraph(.data) if(manynet::is_weighted(data) & getDependentName(formula)=="weight"){ DV <- manynet::as_matrix(data) } else DV <- manynet::as_matrix(data) @@ -350,11 +350,30 @@ convertToMatrixList <- function(formula, data){ } # same #### } else if (IV[[elem]][1] == "same"){ - rows <- matrix(manynet::node_attribute(data, IV[[elem]][2]), - nrow(DV), ncol(DV)) - cols <- matrix(manynet::node_attribute(data, IV[[elem]][2]), - nrow(DV), ncol(DV), byrow = TRUE) - out <- (rows==cols)*1 + attrib <- manynet::node_attribute(data, IV[[elem]][2]) + if(manynet::is_twomode(.data)){ + if(all(is.na(attrib[!manynet::node_is_mode(.data)]))){ # if 2nd mode + attrib <- attrib[manynet::node_is_mode(.data)] + out <- vapply(1:length(attrib), function(x){ + net <- manynet::as_matrix(manynet::delete_nodes(.data, net_dims(.data)[1]+x)) + rowSums(net * matrix((attrib[-x]==attrib[x])*1, + nrow(DV), ncol(DV)-1, byrow = TRUE))/ + rowSums(net) + }, FUN.VALUE = numeric(nrow(DV))) + } else { # or then attrib must be on first mode + attrib <- attrib[!manynet::node_is_mode(.data)] + out <- t(vapply(1:length(attrib), function(x){ + net <- manynet::as_matrix(manynet::delete_nodes(.data, x)) + colSums(net * matrix((attrib[-x]==attrib[x])*1, + nrow(DV)-1, ncol(DV)))/ + colSums(net) + }, FUN.VALUE = numeric(ncol(DV)))) + } + } else { + rows <- matrix(attrib, nrow(DV), ncol(DV)) + cols <- matrix(attrib, nrow(DV), ncol(DV), byrow = TRUE) + out <- (rows==cols)*1 + } out <- list(out) names(out) <- paste(IV[[elem]], collapse = " ") out <- out From 39021a410f4a2e38603dc2450915a819c81cd0d6 Mon Sep 17 00:00:00 2001 From: James Hollway Date: Sat, 30 Nov 2024 15:39:12 +0100 Subject: [PATCH 8/9] #patch bump --- DESCRIPTION | 6 +++--- NEWS.md | 17 +++++++++++++++++ R/model_regression.R | 2 +- 3 files changed, 21 insertions(+), 4 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 9814d138..9e0fc082 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,7 +1,7 @@ Package: migraph Title: Univariate and Multivariate Tests for Multimodal and Other Networks -Version: 1.4.3 -Date: 2024-11-06 +Version: 1.4.4 +Date: 2024-11-30 Description: A set of tools for testing networks. It includes functions for univariate and multivariate conditional uniform graph and quadratic assignment procedure testing, @@ -32,7 +32,7 @@ Imports: Suggests: covr, roxygen2, - testthat + testthat (>= 3.0.0) Authors@R: c(person(given = "James", family = "Hollway", diff --git a/NEWS.md b/NEWS.md index fec7d32d..e429f03d 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,3 +1,20 @@ +# migraph 1.4.4 + +2024-11-06 + +## Package + +- Updated github actions + +## Models + +- Updated `net_regression()` + - It now works (better) with unweighted networks + - Added print methods that combine `tidy()` and `glance()` + - Fixed effect naming error + - Updated `same()` to work for two-mode networks + - Updated specification advice for testing for homophily in two-mode networks + # migraph 1.4.3 2024-11-06 diff --git a/R/model_regression.R b/R/model_regression.R index 2e720a01..03e4ed74 100644 --- a/R/model_regression.R +++ b/R/model_regression.R @@ -489,7 +489,7 @@ specificationAdvice <- function(formula, data){ suggests <- paste0(suggests, collapse = ", ") cat(paste("When testing for homophily,", "it is recommended to include all more fundamental effects.\n", - "Try adding", suggests, "to the model specification.")) + "Try adding", suggests, "to the model specification.\n\n")) } } } From ab2405dd49c9dc9b82fc1d2ea3dd71470f4d98a4 Mon Sep 17 00:00:00 2001 From: James Hollway Date: Sat, 30 Nov 2024 15:54:52 +0100 Subject: [PATCH 9/9] Fixed minor documentation issues --- DESCRIPTION | 6 +++--- NEWS.md | 10 +++++++++- R/data_mpn.R | 2 +- R/model_regression.R | 3 ++- man/mpn_elite_usa.Rd | 2 +- 5 files changed, 16 insertions(+), 7 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 9e0fc082..0850daf0 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,6 +1,6 @@ Package: migraph Title: Univariate and Multivariate Tests for Multimodal and Other Networks -Version: 1.4.4 +Version: 1.4.5 Date: 2024-11-30 Description: A set of tools for testing networks. It includes functions for univariate and multivariate @@ -9,8 +9,8 @@ Description: A set of tools for testing networks. The package is a complement to 'Multimodal Political Networks' (2021, ISBN:9781108985000), and includes various datasets used in the book. - Built on the 'manynet' package, all functions operate with matrices, edge lists, - and 'igraph', 'network', and 'tidygraph' objects, + Built on the 'manynet' package, all functions operate with matrices, + edge lists, and 'igraph', 'network', and 'tidygraph' objects, and on one-mode and two-mode (bipartite) networks. URL: https://stocnet.github.io/migraph/ BugReports: https://github.com/stocnet/migraph/issues diff --git a/NEWS.md b/NEWS.md index e429f03d..e984d213 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,6 +1,14 @@ # migraph 1.4.4 -2024-11-06 +2024-11-30 + +## Package + +- Fixed dependency issue + +# migraph 1.4.4 + +2024-11-29 ## Package diff --git a/R/data_mpn.R b/R/data_mpn.R index a108d8be..6b1fcd41 100644 --- a/R/data_mpn.R +++ b/R/data_mpn.R @@ -79,7 +79,7 @@ #' @references #' Domhoff, G William. 2016. \href{https://whorulesamerica.ucsc.edu/power_elite/}{“Who Rules America? Power Elite Database.”} #' -#' The Center for Responsive Politics. 2019. \href{https://www.opensecrets.org}{“OpenSecrets.”} +#' The Center for Responsive Politics. 2019. “OpenSecrets.” https://www.opensecrets.org. #' #' Knoke, David, Mario Diani, James Hollway, and Dimitris C Christopoulos. 2021. #' \href{https://www.cambridge.org/core/books/multimodal-political-networks/43EE8C192A1B0DCD65B4D9B9A7842128}{\emph{Multimodal Political Networks}}. diff --git a/R/model_regression.R b/R/model_regression.R index 03e4ed74..ee461e3c 100644 --- a/R/model_regression.R +++ b/R/model_regression.R @@ -355,7 +355,8 @@ convertToMatrixList <- function(formula, .data){ if(all(is.na(attrib[!manynet::node_is_mode(.data)]))){ # if 2nd mode attrib <- attrib[manynet::node_is_mode(.data)] out <- vapply(1:length(attrib), function(x){ - net <- manynet::as_matrix(manynet::delete_nodes(.data, net_dims(.data)[1]+x)) + net <- manynet::as_matrix(manynet::delete_nodes(.data, + manynet::net_dims(.data)[1]+x)) rowSums(net * matrix((attrib[-x]==attrib[x])*1, nrow(DV), ncol(DV)-1, byrow = TRUE))/ rowSums(net) diff --git a/man/mpn_elite_usa.Rd b/man/mpn_elite_usa.Rd index b6b114f5..30970846 100644 --- a/man/mpn_elite_usa.Rd +++ b/man/mpn_elite_usa.Rd @@ -80,7 +80,7 @@ or the Democratic Party (Hillary Clinton, Christopher Dodd, Barack Obama). \references{ Domhoff, G William. 2016. \href{https://whorulesamerica.ucsc.edu/power_elite/}{“Who Rules America? Power Elite Database.”} -The Center for Responsive Politics. 2019. \href{https://www.opensecrets.org}{“OpenSecrets.”} +The Center for Responsive Politics. 2019. “OpenSecrets.” https://www.opensecrets.org. Knoke, David, Mario Diani, James Hollway, and Dimitris C Christopoulos. 2021. \href{https://www.cambridge.org/core/books/multimodal-political-networks/43EE8C192A1B0DCD65B4D9B9A7842128}{\emph{Multimodal Political Networks}}.