Concetto di proiezione

Analisi di reti intermedia in Python

Eric Ma

Data Carpentry instructor and author of nxviz package

Proiezione

  • Rappresentazione unipartita della connettività bipartita
    • Condizionata alle connessioni con i nodi dell’altra partizione
Analisi di reti intermedia in Python

Proiezione

  • Rappresentazione unipartita della connettività bipartita

ch2-1.006.png

Analisi di reti intermedia in Python

Proiezione

  • Rappresentazione unipartita della connettività bipartita

ch2-1.007.png

Analisi di reti intermedia in Python

Proiezione

  • Rappresentazione unipartita della connettività bipartita

ch2-1.008.png

Analisi di reti intermedia in Python

Proiezione

  • Rappresentazione unipartita della connettività bipartita

ch2-1.009.png

Analisi di reti intermedia in Python

Grafi su disco

  • Edge list piatte
  • File CSV: nodelist + metadati, edgelist + metadati
Analisi di reti intermedia in Python

Lettura dei dati di rete

import networkx as nx
G = nx.read_edgelist('american-revolution.txt')

list(G.edges(data=True))[0:5]
[('Parkman.Elias', 'LondonEnemies', {'weight': 1}),
 ('Parkman.Elias', 'NorthCaucus', {'weight': 1}),
 ('Inglish.Alexander', 'StAndrewsLodge', {'weight': 1}),
 ('NorthCaucus', 'Chadwell.Mr', {'weight': 1}),
 ('NorthCaucus', 'Pearce.IsaacJun', {'weight': 1})]
  • File di testo
    Barrett.Samuel LondonEnemies {'weight': 1}
    Barrett.Samuel StAndrewsLodge {'weight': 1}
    Marshall.Thomas LondonEnemies {'weight': 1}
    Eaton.Joseph TeaParty {'weight': 1}
    Bass.Henry LondonEnemies {'weight': 1}
    
Analisi di reti intermedia in Python

Proiezione bipartita

list(G.nodes())
['product2', 'customer3', 'customer1', 'product3',  
    'customer2', 'product1']
list(G.edges())
[('product2', 'customer1'),
 ('product2', 'customer2'),
 ('customer3', ‘product1')]
Analisi di reti intermedia in Python

Proiezione bipartita

cust_nodes = [n for n in G.nodes() if G.nodes[n]
                  ['bipartite'] == 'customers']
cust_nodes
['customer3', 'customer1', 'customer2']
Analisi di reti intermedia in Python

Proiezione bipartita

G_cust = nx.bipartite.projected_graph(G, cust_nodes)
list(G_cust.nodes())
['customer1', 'customer3', 'customer2']
list(G_cust.edges())
[('customer1', 'customer2')]
Analisi di reti intermedia in Python

Degree centrality

  • Ricorda la definizione di degree centrality $$\frac{\text{number of neighbors}}{\text{number of possible neighbors}}$$
  • Denominatore: numero di nodi nella partizione opposta
Analisi di reti intermedia in Python

Degree centrality bipartita

nx.bipartite.degree_centrality(G, cust_nodes)
{'customer1': 0.3333333333333333,
 'customer2': 0.3333333333333333,
 'customer3': 0.3333333333333333,
 'product1': 0.3333333333333333,
 'product2': 0.6666666666666666,
 'product3': 0.0}
Analisi di reti intermedia in Python

Degree centrality bipartita

nx.degree_centrality(G)
{'customer1': 0.2,
 'customer2': 0.2,
 'customer3': 0.2,
 'product1': 0.2,
 'product2': 0.4,
 'product3': 0.0}
Analisi di reti intermedia in Python

Ayo berlatih!

Analisi di reti intermedia in Python

Preparing Video For Download...