AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 78872286
Accepted
farrow90
farrow90
Asked: 2024-08-15 01:37:00 +0800 CST2024-08-15 01:37:00 +0800 CST 2024-08-15 01:37:00 +0800 CST

Otimizando Funções para Gráficos de Rede

  • 772

Nesta questão aqui ( Somando nós em uma rede ), aprendi como encontrar o quadrado dentro da rede original com a maior soma de nós.

Aqui estão os dados para esta pergunta:

library(igraph)

width <- 30
height <- 20
num_nodes <- width * height

# Create a grid
x <- rep(1:width, each = height)
y <- rep(1:height, times = width)

g <- make_empty_graph(n = num_nodes, directed = FALSE)

# Function to get node index
get_node_index <- function(i, j) (i - 1) * height + j

# Add edges
edges <- c()
for(i in 1:width) {
   for(j in 1:height) {
      current_node <- get_node_index(i, j)
    
      # Connect to right neighbor
      if(i < width) edges <- c(edges, current_node, get_node_index(i + 1, j))
    
      # Connect to bottom neighbor
      if(j < height) edges <- c(edges, current_node, get_node_index(i, j + 1))
   }
}

g <- add_edges(g, edges)

V(g)$x <- x
V(g)$y <- y

par(mfrow=c(1,2))

V(g)$name <- 1:num_nodes
plot(g, vertex.size = 7, vertex.label = V(g)$name, vertex.label.cex = 0.6, main = "Map with         Node Indices")

V(g)$value <- sample(1:100, num_nodes, replace = TRUE)
plot(g, vertex.size = 7, vertex.label = V(g)$value, vertex.label.cex = 0.6, main = "Map with     Population Values")

E aqui está a função:

sg <- subgraph_isomorphisms(make_ring(4), g)
lst <- unique(lapply(sg, \(x) sort(names(x))))
out <- do.call(
  rbind,
  lapply(
    lst,
    \(v) data.frame(
      node_id = toString(v),
      value = sum(V(induced_subgraph(g, v))$value)
    )
  )
)

Esta abordagem está atualmente usando uma abordagem de força bruta em que cada nó é verificado individualmente. Existe alguma maneira em R de reestruturar essa função para que ela seja executada em paralelo ou um tipo diferente de algoritmo de busca que possa varrer a rede com mais eficiência?

Eu tive duas ideias sobre isso:

  1. Ideia 1:

    Reescrevendo a função para observar grades quadradas e tesselá-las na rede:

     efficient_sum_squares <- function(g, width, height) {
       results <- data.frame(node_id = character(), value = numeric())
    
       for (i in 1:(width - 1)) {
         for (j in 1:(height - 1)) {
           nodes <- c(
             get_node_index(i, j),
             get_node_index(i + 1, j),
             get_node_index(i, j + 1),
             get_node_index(i + 1, j + 1)
           )
    
           sum_value <- sum(V(g)$value[nodes])
    
           results <- rbind(results, data.frame(node_id = toString(nodes), value = sum_value))
         }
       }
    
       results
     }
    
     out_efficient <- efficient_sum_squares(g, width, height)
    
  2. Ideia 2:

    Achei que as comparações poderiam ser feitas de forma vetorizada:

     vectorized_sum_squares <- function(g, width, height) {
       x_mat <- matrix(V(g)$x, nrow = height, ncol = width, byrow = FALSE)
       y_mat <- matrix(V(g)$y, nrow = height, ncol = width, byrow = FALSE)
       value_mat <- matrix(V(g)$value, nrow = height, ncol = width, byrow = FALSE)
    
       sums <- value_mat[1:(height-1), 1:(width-1)] + 
               value_mat[2:height, 1:(width-1)] + 
               value_mat[1:(height-1), 2:width] + 
               value_mat[2:height, 2:width]
    
       node_ids <- apply(which(sums == sums, arr.ind = TRUE), 1, function(idx) {
         i <- idx[1]
         j <- idx[2]
         toString(c(
           get_node_index(j, i),
           get_node_index(j + 1, i),
           get_node_index(j, i + 1),
           get_node_index(j + 1, i + 1)
         ))
       })
    
       data.frame(node_id = node_ids, value = as.vector(sums))
     }
    
     out_vectorized <- vectorized_sum_squares(g, width, height)
    

Existe alguma maneira melhor de trabalhar nesse problema?

  • 1 1 respostas
  • 41 Views

1 respostas

  • Voted
  1. Best Answer
    ThomasIsCoding
    2024-08-15T19:44:23+08:002024-08-15T19:44:23+08:00

    Se você pesquisar esses quadrados (consistindo de 4nós adjacentes) em uma grade, você realmente não precisa igraphdisso. A segunda ideia é boa o suficiente se você trabalhar apenas com uma matriz e igraphas operações puderem ser evitadas.

    Aqui está um exemplo semelhante à 2ª abordagem

    set.seed(0)
    width <- 15
    height <- 10
    gmat <- matrix(sample.int(10, width * height, replace = TRUE), height)
    
    ul <- gmat[-height, -width]
    ur <- gmat[-height, -1]
    dl <- gmat[-1, -width]
    dr <- gmat[-1, -1]
    
    ssum <- ul + ur + dl + dr
    idx <- apply(
      which(ssum == max(ssum), TRUE),
      1,
      \(x) {
        toString(crossprod(
          c(height, 1),
          x + cbind(
            c(-1, 0),
            c(-1, 1),
            c(0, 0),
            c(0, 1)
          )
        ))
      }
    )
    
    res <- data.frame(node_id = idx, value = max(ssum))
    

    e você vê isso

    > gmat
          [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13]
     [1,]    2    3    1    2    3    3    2    1    1     3     1     2     3
     [2,]    1    3    3    2    2    3    1    1    1     2     2     1     1
     [3,]    3    1    1    1    1    2    3    1    1     2     2     3     1
     [4,]    1    1    1    3    3    2    3    1    1     2     1     3     2
     [5,]    2    1    1    1    2    2    2    3    3     3     3     1     2
     [6,]    1    2    1    3    1    2    3    2    2     2     3     2     2
     [7,]    3    2    2    2    1    1    3    3    1     2     2     1     1
     [8,]    3    2    1    2    3    2    2    1    1     3     3     3     1
     [9,]    2    2    1    2    2    2    3    1    3     3     2     2     1
    [10,]    2    3    2    2    2    2    3    2    3     3     1     3     2
          [,14] [,15]
     [1,]     1     2
     [2,]     3     2
     [3,]     2     1
     [4,]     3     2
     [5,]     3     3
     [6,]     2     3
     [7,]     3     3
     [8,]     3     3
     [9,]     1     3
    [10,]     1     1
    

    e

    > res
              node_id value
    1 89, 90, 99, 100    12
    2  74, 75, 84, 85    12
    
    • 1

relate perguntas

  • Adicionar número de série para atividade de cópia ao blob

  • A fonte dinâmica do empacotador duplica artefatos

  • Selecione linhas por grupo com 1s consecutivos

  • Lista de chamada de API de gráfico subscritoSkus estados Privilégios insuficientes enquanto os privilégios são concedidos

  • Função para criar DFs separados com base no valor da coluna

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Por que esse código Java simples e pequeno roda 30x mais rápido em todas as JVMs Graal, mas não em nenhuma JVM Oracle?

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Quando devo usar um std::inplace_vector em vez de um std::vector?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Marko Smith

    Estou tentando fazer o jogo pacman usando apenas o módulo Turtle Random e Math

    • 1 respostas
  • Martin Hope
    Aleksandr Dubinsky Por que a correspondência de padrões com o switch no InetAddress falha com 'não cobre todos os valores de entrada possíveis'? 2024-12-23 06:56:21 +0800 CST
  • Martin Hope
    Phillip Borge Por que esse código Java simples e pequeno roda 30x mais rápido em todas as JVMs Graal, mas não em nenhuma JVM Oracle? 2024-12-12 20:46:46 +0800 CST
  • Martin Hope
    Oodini Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores? 2024-12-12 06:27:11 +0800 CST
  • Martin Hope
    sleeptightAnsiC `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso? 2024-11-09 07:18:53 +0800 CST
  • Martin Hope
    The Mad Gamer Quando devo usar um std::inplace_vector em vez de um std::vector? 2024-10-29 23:01:00 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST
  • Martin Hope
    MarkB Por que o GCC gera código que executa condicionalmente uma implementação SIMD? 2024-02-17 06:17:14 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve