File: igraph_ES.html

package info (click to toggle)
r-cran-igraph 2.1.4-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 27,044 kB
  • sloc: ansic: 204,981; cpp: 21,711; fortran: 4,090; yacc: 1,229; lex: 519; sh: 52; makefile: 8
file content (1492 lines) | stat: -rw-r--r-- 590,757 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8" />
<meta name="generator" content="pandoc" />
<meta http-equiv="X-UA-Compatible" content="IE=EDGE" />

<meta name="viewport" content="width=device-width, initial-scale=1" />



<title>igraph (interfaz R)</title>

<script>// Pandoc 2.9 adds attributes on both header and div. We remove the former (to
// be compatible with the behavior of Pandoc < 2.8).
document.addEventListener('DOMContentLoaded', function(e) {
  var hs = document.querySelectorAll("div.section[class*='level'] > :first-child");
  var i, h, a;
  for (i = 0; i < hs.length; i++) {
    h = hs[i];
    if (!/^h[1-6]$/i.test(h.tagName)) continue;  // it should be a header h1-h6
    a = h.attributes;
    while (a.length > 0) h.removeAttribute(a[0].name);
  }
});
</script>

<style type="text/css">
code{white-space: pre-wrap;}
span.smallcaps{font-variant: small-caps;}
span.underline{text-decoration: underline;}
div.column{display: inline-block; vertical-align: top; width: 50%;}
div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;}
ul.task-list{list-style: none;}
</style>



<style type="text/css">
code {
white-space: pre;
}
.sourceCode {
overflow: visible;
}
</style>
<style type="text/css" data-origin="pandoc">
html { -webkit-text-size-adjust: 100%; }
pre > code.sourceCode { white-space: pre; position: relative; }
pre > code.sourceCode > span { display: inline-block; line-height: 1.25; }
pre > code.sourceCode > span:empty { height: 1.2em; }
.sourceCode { overflow: visible; }
code.sourceCode > span { color: inherit; text-decoration: inherit; }
div.sourceCode { margin: 1em 0; }
pre.sourceCode { margin: 0; }
@media screen {
div.sourceCode { overflow: auto; }
}
@media print {
pre > code.sourceCode { white-space: pre-wrap; }
pre > code.sourceCode > span { text-indent: -5em; padding-left: 5em; }
}
pre.numberSource code
{ counter-reset: source-line 0; }
pre.numberSource code > span
{ position: relative; left: -4em; counter-increment: source-line; }
pre.numberSource code > span > a:first-child::before
{ content: counter(source-line);
position: relative; left: -1em; text-align: right; vertical-align: baseline;
border: none; display: inline-block;
-webkit-touch-callout: none; -webkit-user-select: none;
-khtml-user-select: none; -moz-user-select: none;
-ms-user-select: none; user-select: none;
padding: 0 4px; width: 4em;
color: #aaaaaa;
}
pre.numberSource { margin-left: 3em; border-left: 1px solid #aaaaaa; padding-left: 4px; }
div.sourceCode
{ }
@media screen {
pre > code.sourceCode > span > a:first-child::before { text-decoration: underline; }
}
code span.al { color: #ff0000; font-weight: bold; } 
code span.an { color: #60a0b0; font-weight: bold; font-style: italic; } 
code span.at { color: #7d9029; } 
code span.bn { color: #40a070; } 
code span.bu { color: #008000; } 
code span.cf { color: #007020; font-weight: bold; } 
code span.ch { color: #4070a0; } 
code span.cn { color: #880000; } 
code span.co { color: #60a0b0; font-style: italic; } 
code span.cv { color: #60a0b0; font-weight: bold; font-style: italic; } 
code span.do { color: #ba2121; font-style: italic; } 
code span.dt { color: #902000; } 
code span.dv { color: #40a070; } 
code span.er { color: #ff0000; font-weight: bold; } 
code span.ex { } 
code span.fl { color: #40a070; } 
code span.fu { color: #06287e; } 
code span.im { color: #008000; font-weight: bold; } 
code span.in { color: #60a0b0; font-weight: bold; font-style: italic; } 
code span.kw { color: #007020; font-weight: bold; } 
code span.op { color: #666666; } 
code span.ot { color: #007020; } 
code span.pp { color: #bc7a00; } 
code span.sc { color: #4070a0; } 
code span.ss { color: #bb6688; } 
code span.st { color: #4070a0; } 
code span.va { color: #19177c; } 
code span.vs { color: #4070a0; } 
code span.wa { color: #60a0b0; font-weight: bold; font-style: italic; } 
</style>
<script>
// apply pandoc div.sourceCode style to pre.sourceCode instead
(function() {
  var sheets = document.styleSheets;
  for (var i = 0; i < sheets.length; i++) {
    if (sheets[i].ownerNode.dataset["origin"] !== "pandoc") continue;
    try { var rules = sheets[i].cssRules; } catch (e) { continue; }
    var j = 0;
    while (j < rules.length) {
      var rule = rules[j];
      // check if there is a div.sourceCode rule
      if (rule.type !== rule.STYLE_RULE || rule.selectorText !== "div.sourceCode") {
        j++;
        continue;
      }
      var style = rule.style.cssText;
      // check if color or background-color is set
      if (rule.style.color === '' && rule.style.backgroundColor === '') {
        j++;
        continue;
      }
      // replace div.sourceCode by a pre.sourceCode rule
      sheets[i].deleteRule(j);
      sheets[i].insertRule('pre.sourceCode{' + style + '}', j);
    }
  }
})();
</script>




<style type="text/css">body {
background-color: #fff;
margin: 1em auto;
max-width: 700px;
overflow: visible;
padding-left: 2em;
padding-right: 2em;
font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
font-size: 14px;
line-height: 1.35;
}
#TOC {
clear: both;
margin: 0 0 10px 10px;
padding: 4px;
width: 400px;
border: 1px solid #CCCCCC;
border-radius: 5px;
background-color: #f6f6f6;
font-size: 13px;
line-height: 1.3;
}
#TOC .toctitle {
font-weight: bold;
font-size: 15px;
margin-left: 5px;
}
#TOC ul {
padding-left: 40px;
margin-left: -1.5em;
margin-top: 5px;
margin-bottom: 5px;
}
#TOC ul ul {
margin-left: -2em;
}
#TOC li {
line-height: 16px;
}
table {
margin: 1em auto;
border-width: 1px;
border-color: #DDDDDD;
border-style: outset;
border-collapse: collapse;
}
table th {
border-width: 2px;
padding: 5px;
border-style: inset;
}
table td {
border-width: 1px;
border-style: inset;
line-height: 18px;
padding: 5px 5px;
}
table, table th, table td {
border-left-style: none;
border-right-style: none;
}
table thead, table tr.even {
background-color: #f7f7f7;
}
p {
margin: 0.5em 0;
}
blockquote {
background-color: #f6f6f6;
padding: 0.25em 0.75em;
}
hr {
border-style: solid;
border: none;
border-top: 1px solid #777;
margin: 28px 0;
}
dl {
margin-left: 0;
}
dl dd {
margin-bottom: 13px;
margin-left: 13px;
}
dl dt {
font-weight: bold;
}
ul {
margin-top: 0;
}
ul li {
list-style: circle outside;
}
ul ul {
margin-bottom: 0;
}
pre, code {
background-color: #f7f7f7;
border-radius: 3px;
color: #333;
white-space: pre-wrap; 
}
pre {
border-radius: 3px;
margin: 5px 0px 10px 0px;
padding: 10px;
}
pre:not([class]) {
background-color: #f7f7f7;
}
code {
font-family: Consolas, Monaco, 'Courier New', monospace;
font-size: 85%;
}
p > code, li > code {
padding: 2px 0px;
}
div.figure {
text-align: center;
}
img {
background-color: #FFFFFF;
padding: 2px;
border: 1px solid #DDDDDD;
border-radius: 3px;
border: 1px solid #CCCCCC;
margin: 0 5px;
}
h1 {
margin-top: 0;
font-size: 35px;
line-height: 40px;
}
h2 {
border-bottom: 4px solid #f7f7f7;
padding-top: 10px;
padding-bottom: 2px;
font-size: 145%;
}
h3 {
border-bottom: 2px solid #f7f7f7;
padding-top: 10px;
font-size: 120%;
}
h4 {
border-bottom: 1px solid #f7f7f7;
margin-left: 8px;
font-size: 105%;
}
h5, h6 {
border-bottom: 1px solid #ccc;
font-size: 105%;
}
a {
color: #0033dd;
text-decoration: none;
}
a:hover {
color: #6666ff; }
a:visited {
color: #800080; }
a:visited:hover {
color: #BB00BB; }
a[href^="http:"] {
text-decoration: underline; }
a[href^="https:"] {
text-decoration: underline; }

code > span.kw { color: #555; font-weight: bold; } 
code > span.dt { color: #902000; } 
code > span.dv { color: #40a070; } 
code > span.bn { color: #d14; } 
code > span.fl { color: #d14; } 
code > span.ch { color: #d14; } 
code > span.st { color: #d14; } 
code > span.co { color: #888888; font-style: italic; } 
code > span.ot { color: #007020; } 
code > span.al { color: #ff0000; font-weight: bold; } 
code > span.fu { color: #900; font-weight: bold; } 
code > span.er { color: #a61717; background-color: #e3d2d2; } 
</style>




</head>

<body>




<h1 class="title toc-ignore">igraph (interfaz R)</h1>


<div id="TOC">
<ul>
<li><a href="#instalaci%C3%B3n" id="toc-instalación">Instalación</a></li>
<li><a href="#uso-de-igraph" id="toc-uso-de-igraph">Uso de
igraph</a></li>
<li><a href="#crear-un-grafo" id="toc-crear-un-grafo">Crear un
grafo</a></li>
<li><a href="#ids-de-v%C3%A9rtices-y-aristas" id="toc-ids-de-vértices-y-aristas">IDs de vértices y aristas</a></li>
<li><a href="#a%C3%B1adir-y-borrar-v%C3%A9rtices-y-aristas" id="toc-añadir-y-borrar-vértices-y-aristas">Añadir y borrar vértices y
aristas</a></li>
<li><a href="#construcci%C3%B3n-de-grafos" id="toc-construcción-de-grafos">Construcción de grafos</a></li>
<li><a href="#establecer-y-recuperar-atributos" id="toc-establecer-y-recuperar-atributos">Establecer y recuperar
atributos</a></li>
<li><a href="#propiedades-estructurales-de-los-grafos" id="toc-propiedades-estructurales-de-los-grafos">Propiedades
estructurales de los grafos</a></li>
<li><a href="#b%C3%BAsqueda-de-v%C3%A9rtices-y-aristas-basada-en-atributos" id="toc-búsqueda-de-vértices-y-aristas-basada-en-atributos">Búsqueda de
vértices y aristas basada en atributos</a>
<ul>
<li><a href="#selecci%C3%B3n-de-v%C3%A9rtices" id="toc-selección-de-vértices">Selección de vértices</a></li>
<li><a href="#selecci%C3%B3n-de-aristas" id="toc-selección-de-aristas">Selección de aristas</a></li>
</ul></li>
<li><a href="#tratar-un-grafo-como-una-matriz-de-adyacencia" id="toc-tratar-un-grafo-como-una-matriz-de-adyacencia">Tratar un grafo
como una matriz de adyacencia</a></li>
<li><a href="#dise%C3%B1os-y-graficaci%C3%B3n" id="toc-diseños-y-graficación">Diseños y graficación</a>
<ul>
<li><a href="#algoritmos-de-dise%C3%B1o" id="toc-algoritmos-de-diseño">Algoritmos de diseño</a></li>
<li><a href="#dibujar-un-grafo-utilizando-un-dise%C3%B1o" id="toc-dibujar-un-grafo-utilizando-un-diseño">Dibujar un grafo
utilizando un diseño</a></li>
<li><a href="#atributos-de-los-v%C3%A9rtices-para-graficar" id="toc-atributos-de-los-vértices-para-graficar">Atributos de los
vértices para graficar</a></li>
<li><a href="#atributos-de-las-aristas-para-graficar" id="toc-atributos-de-las-aristas-para-graficar">Atributos de las aristas
para graficar</a></li>
<li><a href="#argumentos-m%C3%A1s-comunes-de-plot" id="toc-argumentos-más-comunes-de-plot">Argumentos más comunes de
<code>plot()</code></a></li>
</ul></li>
<li><a href="#igraph-y-el-mundo-exterior" id="toc-igraph-y-el-mundo-exterior">igraph y el mundo exterior</a></li>
<li><a href="#d%C3%B3nde-ir-a-continuaci%C3%B3n" id="toc-dónde-ir-a-continuación">Dónde ir a continuación</a></li>
<li><a href="#informaci%C3%B3n-de-la-sesi%C3%B3n" id="toc-información-de-la-sesión">Información de la sesión</a></li>
</ul>
</div>

<p><code>igraph</code> es una biblioteca rápida y de código abierto para
el análisis de grafos o redes. El núcleo de ésta libreria se encuentra
escrito en C y contiene enlaces para lenguajes de alto nivel como <a href="https://r.igraph.org/">R</a>, <a href="https://python.igraph.org/">Python</a>, y <a href="http://szhorvat.net/pelican/igraphm-a-mathematica-interface-for-igraph.html">Mathematica</a>.
Esta viñeta pretende darte una visión general de las funciones
disponibles de <code>igraph</code> en R. Para obtener información
detallada de cada función, consulta <a href="https://r.igraph.org/reference/" class="uri">https://r.igraph.org/reference/</a>.</p>
<hr />
<p><strong>NOTA:</strong> A lo largo de este tutorial, utilizaremos las
palabras <code>grafo</code> y <code>red</code> como sinónimos, y también
<code>vértice</code> o <code>nodo</code> como sinónimos.</p>
<hr />
<div id="instalación" class="section level2">
<h2>Instalación</h2>
<p>Para instalar la librería desde CRAN, usa:</p>
<div class="sourceCode" id="cb1"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb1-1"><a href="#cb1-1" tabindex="-1"></a><span class="fu">install.packages</span>(<span class="st">&quot;igraph&quot;</span>)</span></code></pre></div>
<p>Encontrarás más información sobre dependencias, requisitos y
resolución de problemas sobre la instalación en la <a href="https://r.igraph.org/">página principal</a>.</p>
</div>
<div id="uso-de-igraph" class="section level2">
<h2>Uso de igraph</h2>
<p>Para utilizar <code>igraph</code> en tu código de R, primero debes
cargar la biblioteca:</p>
<div class="sourceCode" id="cb2"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb2-1"><a href="#cb2-1" tabindex="-1"></a><span class="fu">library</span>(<span class="st">&quot;igraph&quot;</span>)</span></code></pre></div>
<p>Ahora tienes todas las funciones de <code>igraph</code>
disponibles.</p>
</div>
<div id="crear-un-grafo" class="section level2">
<h2>Crear un grafo</h2>
<p><code>igraph</code> ofrece muchas formas de crear un grafo. La más
sencilla es con la función <code>make_empty_graph()</code>:</p>
<div class="sourceCode" id="cb3"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb3-1"><a href="#cb3-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">make_empty_graph</span>()</span></code></pre></div>
<p>La forma más común de crear un grafo es con
<code>make_graph()</code>, que construye un grafo basado en especificar
las aristas. Por ejemplo, Para hacer un grafo con 10 nodos (numerados
<code>1</code> a <code>10</code>) y dos aristas que conecten los nodos
<code>1-2</code> y <code>1-5</code>:</p>
<div class="sourceCode" id="cb4"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb4-1"><a href="#cb4-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">make_graph</span>(<span class="at">edges =</span> <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">2</span>, <span class="dv">1</span>,<span class="dv">5</span>), <span class="at">n=</span><span class="dv">10</span>, <span class="at">directed =</span> <span class="cn">FALSE</span>)</span></code></pre></div>
<p>A partir de igraph 0.8.0, también puedes incluir literales mediante
la notación de fórmulas de igraph. En este caso, el primer término de la
fórmula tiene que empezar con un carácter <code>~</code>, como
comúnmente se usa en las fórmulas en R. Las expresiones constan de los
nombres de los vértices y los operadores de las aristas. El operador de
un arista es una secuencia de caracteres <code>-</code> y
<code>+</code>, el primero es para indicar propiamente las aristas y el
segundo para las puntas de flecha (dirección). Puedes utilizar tantos
caracteres <code>-</code> como quieras para “dibujarlas”. Si todos los
operadores de un arista están formados únicamente por caracteres
<code>-</code>, el grafo será no dirigido, mientras que un único
carácter <code>+</code> implica un grafo dirigido. Por ejemplo, para
crear el mismo grafo que antes:</p>
<div class="sourceCode" id="cb5"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb5-1"><a href="#cb5-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">make_graph</span>(<span class="sc">~</span> <span class="dv">1</span><span class="sc">--</span><span class="dv">2</span>, <span class="dv">1</span><span class="sc">--</span><span class="dv">5</span>, <span class="dv">3</span>, <span class="dv">4</span>, <span class="dv">5</span>, <span class="dv">6</span>, <span class="dv">7</span>, <span class="dv">8</span>, <span class="dv">9</span>, <span class="dv">10</span>)</span></code></pre></div>
<p>Podemos imprimir el grafo para obtener un resumen de sus nodos y
aristas:</p>
<div class="sourceCode" id="cb6"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb6-1"><a href="#cb6-1" tabindex="-1"></a>g</span></code></pre></div>
<pre><code>## IGRAPH 5034d2d UN-- 10 2 -- 
## + attr: name (v/c)
## + edges from 5034d2d (vertex names):
## [1] 1--2 1--5</code></pre>
<p>Esto significa: grafo no dirigido (<strong>U</strong>ndirected) con
<strong>10</strong> vértices y <strong>2</strong> aristas, que se
enlistan en la última parte. Si el grafo tiene un atributo [nombre],
también se imprime.</p>
<hr />
<p><strong>NOTA</strong>: <code>summary()</code> no enlista las aristas,
lo cual es conveniente para grafos grandes con millones de aristas:</p>
<hr />
<div class="sourceCode" id="cb8"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb8-1"><a href="#cb8-1" tabindex="-1"></a><span class="fu">summary</span>(g)</span></code></pre></div>
<pre><code>## IGRAPH 5034d2d UN-- 10 2 -- 
## + attr: name (v/c)</code></pre>
<p>También <code>make_graph()</code> puede crear algunos grafos
destacados con sólo especificar su nombre. Por ejemplo, puedes generar
el grafo que muestra la red social del club de kárate de Zachary, que
refleja la amistad entre los 34 miembros del club de una universidad de
los Estados Unidos en la década de los 70s:</p>
<div class="sourceCode" id="cb10"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb10-1"><a href="#cb10-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">make_graph</span>(<span class="st">&quot;Zachary&quot;</span>)</span></code></pre></div>
<p>Para observar un grafo puedes utilizar <code>plot()</code>:</p>
<div class="sourceCode" id="cb11"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb11-1"><a href="#cb11-1" tabindex="-1"></a><span class="fu">plot</span>(g)</span></code></pre></div>
<p><img role="img" src="" /><!-- --></p>
<p>Más adelante en este tutorial se ofrece una descripción detallada de
las opciones para graficar un grafo.</p>
</div>
<div id="ids-de-vértices-y-aristas" class="section level2">
<h2>IDs de vértices y aristas</h2>
<p>Los vértices y las aristas tienen un identificador numérico en
igraph. Los ID de los vértices son siempre consecutivos y empiezan por
1. Para un grafo con “n” vértices, los ID de los vértices están siempre
entre 1 y “n”. Si alguna operación cambia el número de vértices en los
grafos, por ejemplo, se crea un subgrafo mediante
<code>induced_subgraph()</code>, entonces los vértices se vuelven a
enumerar para satisfacer este criterio.</p>
<p>Lo mismo ocurre con las aristas: los ID de las aristas están siempre
entre 1 y “m”, el número total de aristas del grafo.</p>
<hr />
<p><strong>NOTA</strong>: Si estás familiarizado con C o con la interfaz
<a href="https://python.igraph.org/en/stable/">Python</a> de
<code>igraph</code>, te habrás dado cuenta de que en esos lenguajes los
IDs de vértices y aristas empiezan por 0. En la interfaz de R, ambos
empiezan por 1, para mantener la coherencia con la convención de cada
lenguaje.</p>
<hr />
<p>Además de los IDs, a los vértices y aristas se les puede asignar un
nombre y otros atributos. Esto facilita su seguimiento cada vez que se
altera un grafo. Más adelante en este tutorial se muestran ejemplos de
cómo alterar estas características.</p>
</div>
<div id="añadir-y-borrar-vértices-y-aristas" class="section level2">
<h2>Añadir y borrar vértices y aristas</h2>
<p>Sigamos trabajando con el grafo del club de kárate. Para añadir uno o
más vértices a un grafo existente, utiliza
<code>add_vertices()</code>:</p>
<div class="sourceCode" id="cb12"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb12-1"><a href="#cb12-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">add_vertices</span>(g, <span class="dv">3</span>)</span></code></pre></div>
<p>Del mismo modo, para añadir aristas puedes utilizar
<code>add_edges()</code>:</p>
<div class="sourceCode" id="cb13"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb13-1"><a href="#cb13-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">add_edges</span>(g, <span class="at">edges =</span> <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">35</span>, <span class="dv">1</span>,<span class="dv">36</span>, <span class="dv">34</span>,<span class="dv">37</span>))</span></code></pre></div>
<p>Las aristas se añaden especificando el ID del vértice origen y el
vértice destino de cada arista. Con las instrucciones anteriores se
añaden tres aristas, una que conecta los vértices <code>1</code> y
<code>35</code>, otra que conecta los vértices <code>1</code> y
<code>36</code> y otra que conecta los vértices <code>34</code> y
<code>37</code>.</p>
<p>Además de las funciones <code>add_vertices()</code> y
<code>add_edges()</code>, se puede utilizar el operador “+” para añadir
vértices o aristas al grafo. La operación que se realice dependerá del
tipo de argumento del lado derecho:</p>
<div class="sourceCode" id="cb14"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb14-1"><a href="#cb14-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> g <span class="sc">+</span> <span class="fu">edges</span>(<span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">35</span>, <span class="dv">1</span>,<span class="dv">36</span>, <span class="dv">34</span>,<span class="dv">37</span>))</span></code></pre></div>
<p>Puedes añadir un solo vértice/arista a la vez usando
<code>add_vertex()</code> y <code>add_edge()</code> (singular).</p>
<p><strong>Advertencia</strong>: Si necesitas añadir múltiples aristas a
un grafo, es mucho más eficiente usar <code>add_edges()</code> una vez
que utilizar repetidamente <code>add_edge()</code> con una nueva arista
a la vez. Lo mismo ocurre al eliminar aristas y vértices.</p>
<p>Si intentas añadir aristas a vértices con IDs no válidos (por
ejemplo, intentas añadir una arista al vértice <code>38</code> cuando el
grafo sólo tiene 37 vértices), <code>igraph</code> muestra un error:</p>
<div class="sourceCode" id="cb15"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb15-1"><a href="#cb15-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">add_edges</span>(g, <span class="at">edges =</span> <span class="fu">c</span>(<span class="dv">38</span>, <span class="dv">37</span>))</span></code></pre></div>
<pre><code>## Error in add_edges(g, edges = c(38, 37)): At vendor/cigraph/src/graph/type_indexededgelist.c:261 : Out-of-range vertex IDs when adding edges. Invalid vertex ID</code></pre>
<p>Añadamos más vértices y aristas a nuestro grafo. En
<code>igraph</code> podemos utilizar el paquete <code>magrittr</code>,
que proporciona un mecanismo para encadenar comandos con el operador
<code>%&gt;%</code>:</p>
<div class="sourceCode" id="cb17"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb17-1"><a href="#cb17-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> g <span class="sc">%&gt;%</span> </span>
<span id="cb17-2"><a href="#cb17-2" tabindex="-1"></a>  <span class="fu">add_edges</span>(<span class="at">edges =</span> <span class="fu">c</span>(<span class="dv">1</span>, <span class="dv">34</span>)) <span class="sc">%&gt;%</span> </span>
<span id="cb17-3"><a href="#cb17-3" tabindex="-1"></a>  <span class="fu">add_vertices</span>(<span class="dv">3</span>) <span class="sc">%&gt;%</span></span>
<span id="cb17-4"><a href="#cb17-4" tabindex="-1"></a>  <span class="fu">add_edges</span>(<span class="at">edges =</span> <span class="fu">c</span>(<span class="dv">38</span>, <span class="dv">39</span>, <span class="dv">39</span>, <span class="dv">40</span>, <span class="dv">40</span>, <span class="dv">38</span>, <span class="dv">40</span>, <span class="dv">37</span>))</span>
<span id="cb17-5"><a href="#cb17-5" tabindex="-1"></a>g</span></code></pre></div>
<pre><code>## IGRAPH 896c648 U--- 40 86 -- Zachary
## + attr: name (g/c)
## + edges from 896c648:
##  [1]  1-- 2  1-- 3  1-- 4  1-- 5  1-- 6  1-- 7  1-- 8  1-- 9  1--11  1--12
## [11]  1--13  1--14  1--18  1--20  1--22  1--32  2-- 3  2-- 4  2-- 8  2--14
## [21]  2--18  2--20  2--22  2--31  3-- 4  3-- 8  3--28  3--29  3--33  3--10
## [31]  3-- 9  3--14  4-- 8  4--13  4--14  5-- 7  5--11  6-- 7  6--11  6--17
## [41]  7--17  9--31  9--33  9--34 10--34 14--34 15--33 15--34 16--33 16--34
## [51] 19--33 19--34 20--34 21--33 21--34 23--33 23--34 24--26 24--28 24--33
## [61] 24--34 24--30 25--26 25--28 25--32 26--32 27--30 27--34 28--34 29--32
## [71] 29--34 30--33 30--34 31--33 31--34 32--33 32--34 33--34  1--35  1--36
## + ... omitted several edges</code></pre>
<p>Ahora tenemos un grafo no dirigido con 40 vértices y 89 aristas. Los
IDs de los vértices y aristas son siempre <em>contiguos</em>, así que si
borras un vértice, todos los vértices subsecuentes se vuelven a
enumerar. Cuando se re-numera un vértice, las aristas
<strong>no</strong> se vuelven a enumerar, pero sí sus vértices origen y
destino. Puedes usar <code>delete_vertices()</code> y
<code>delete_edges()</code> para realizar estas operaciones. Por
ejemplo, para borrar la arista que conecta los vértices
<code>1-34</code>, obtén su ID y luego bórrala:</p>
<div class="sourceCode" id="cb19"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb19-1"><a href="#cb19-1" tabindex="-1"></a>edge_id_para_borrar <span class="ot">&lt;-</span> <span class="fu">get_edge_ids</span>(g, <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">34</span>))</span>
<span id="cb19-2"><a href="#cb19-2" tabindex="-1"></a>edge_id_para_borrar</span></code></pre></div>
<pre><code>## [1] 82</code></pre>
<div class="sourceCode" id="cb21"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb21-1"><a href="#cb21-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">delete_edges</span>(g, edge_id_para_borrar)</span></code></pre></div>
<p>Por ejemplo, para crear un grafo con forma de anillo y para
partirlo:</p>
<div class="sourceCode" id="cb22"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb22-1"><a href="#cb22-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">make_ring</span>(<span class="dv">10</span>) <span class="sc">%&gt;%</span> <span class="fu">delete_edges</span>(<span class="st">&quot;10|1&quot;</span>)</span>
<span id="cb22-2"><a href="#cb22-2" tabindex="-1"></a><span class="fu">plot</span>(g)</span></code></pre></div>
<p><img role="img" src="" /><!-- --></p>
<p>El ejemplo anterior muestra que también puedes referirte a las
aristas indicando los IDs de los vértices origen y destino, conectados
por el símbolo <code>|</code>. En el ejemplo, <code>&quot;10|1&quot;</code>
significa la arista que conecta el vértice <code>10</code> con el
vértice <code>1</code>. Por supuesto, también puedes usar los IDs de las
aristas directamente, o recuperarlos con la función
<code>get_edge_ids()</code>:</p>
<div class="sourceCode" id="cb23"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb23-1"><a href="#cb23-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">make_ring</span>(<span class="dv">5</span>)</span>
<span id="cb23-2"><a href="#cb23-2" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">delete_edges</span>(g, <span class="fu">get_edge_ids</span>(g, <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">5</span>, <span class="dv">4</span>,<span class="dv">5</span>)))</span>
<span id="cb23-3"><a href="#cb23-3" tabindex="-1"></a><span class="fu">plot</span>(g)</span></code></pre></div>
<p><img role="img" src="" /><!-- --></p>
<p>Veamos otro ejemplo, hagamos un grafo cordal. Recuerda que un grafo
es cordal (o triangulado) si cada uno de sus ciclos de cuatro o más
nodos tienen una “cuerda”, que es una arista que une dos nodos que no
son adyacentes en el ciclo. En primer lugar, vamos a crear el grafo
inicial utilizando <code>graph_from_literal()</code>:</p>
<div class="sourceCode" id="cb24"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb24-1"><a href="#cb24-1" tabindex="-1"></a>g1 <span class="ot">&lt;-</span> <span class="fu">graph_from_literal</span>(</span>
<span id="cb24-2"><a href="#cb24-2" tabindex="-1"></a>  A<span class="sc">-</span>B<span class="sc">:</span>C<span class="sc">:</span>I, </span>
<span id="cb24-3"><a href="#cb24-3" tabindex="-1"></a>  B<span class="sc">-</span>A<span class="sc">:</span>C<span class="sc">:</span>D, </span>
<span id="cb24-4"><a href="#cb24-4" tabindex="-1"></a>  C<span class="sc">-</span>A<span class="sc">:</span>B<span class="sc">:</span>E<span class="sc">:</span>H, </span>
<span id="cb24-5"><a href="#cb24-5" tabindex="-1"></a>  D<span class="sc">-</span>B<span class="sc">:</span>E<span class="sc">:</span>F,</span>
<span id="cb24-6"><a href="#cb24-6" tabindex="-1"></a>  E<span class="sc">-</span>C<span class="sc">:</span>D<span class="sc">:</span>F<span class="sc">:</span>H, </span>
<span id="cb24-7"><a href="#cb24-7" tabindex="-1"></a>  F<span class="sc">-</span>D<span class="sc">:</span>E<span class="sc">:</span>G, </span>
<span id="cb24-8"><a href="#cb24-8" tabindex="-1"></a>  G<span class="sc">-</span>F<span class="sc">:</span>H, </span>
<span id="cb24-9"><a href="#cb24-9" tabindex="-1"></a>  H<span class="sc">-</span>C<span class="sc">:</span>E<span class="sc">:</span>G<span class="sc">:</span>I,</span>
<span id="cb24-10"><a href="#cb24-10" tabindex="-1"></a>  I<span class="sc">-</span>A<span class="sc">:</span>H</span>
<span id="cb24-11"><a href="#cb24-11" tabindex="-1"></a>)</span>
<span id="cb24-12"><a href="#cb24-12" tabindex="-1"></a><span class="fu">plot</span>(g1)</span></code></pre></div>
<p><img role="img" src="" /><!-- --></p>
<p>En este ejemplo, se ha utilizado el operador <code>:</code> para
definir conjuntos de vértices. Si el operador de un arista conecta dos
conjuntos de vértices, entonces cada vértice del primer conjunto estará
conectado a cada vértice del segundo conjunto. A continuación utilizamos
<code>is_chordal()</code> para evaluar si nuestro grafo es cordal y
buscar qué aristas faltan para rellenar el grafo:</p>
<div class="sourceCode" id="cb25"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb25-1"><a href="#cb25-1" tabindex="-1"></a><span class="fu">is_chordal</span>(g1, <span class="at">fillin=</span><span class="cn">TRUE</span>)</span></code></pre></div>
<pre><code>## $chordal
## [1] FALSE
## 
## $fillin
##  [1] 2 6 8 7 5 7 2 7 6 1 7 1
## 
## $newgraph
## NULL</code></pre>
<p>Luego, en una sola línea podemos añadir las aristas necesarias para
que el grafo inicial sea cordal:</p>
<div class="sourceCode" id="cb27"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb27-1"><a href="#cb27-1" tabindex="-1"></a>chordal_graph <span class="ot">&lt;-</span> <span class="fu">add_edges</span>(g1, <span class="fu">is_chordal</span>(g1, <span class="at">fillin=</span><span class="cn">TRUE</span>)<span class="sc">$</span>fillin)</span>
<span id="cb27-2"><a href="#cb27-2" tabindex="-1"></a><span class="fu">plot</span>(chordal_graph)</span></code></pre></div>
<p><img role="img" src="" /><!-- --></p>
</div>
<div id="construcción-de-grafos" class="section level2">
<h2>Construcción de grafos</h2>
<p>Además de <code>make_empty_graph()</code>, <code>make_graph()</code>
y <code>make_graph_from_literal()</code>, <code>igraph</code> incluye
muchas otras funciones para construir un grafo. Algunas son
<em>deterministas</em>, es decir, producen el mismo grafo cada vez, por
ejemplo <code>make_tree()</code>:</p>
<div class="sourceCode" id="cb28"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb28-1"><a href="#cb28-1" tabindex="-1"></a>graph1 <span class="ot">&lt;-</span> <span class="fu">make_tree</span>(<span class="dv">127</span>, <span class="dv">2</span>, <span class="at">mode =</span> <span class="st">&quot;undirected&quot;</span>)</span>
<span id="cb28-2"><a href="#cb28-2" tabindex="-1"></a><span class="fu">summary</span>(g)</span></code></pre></div>
<pre><code>## IGRAPH 48b2318 U--- 5 3 -- Ring graph
## + attr: name (g/c), mutual (g/l), circular (g/l)</code></pre>
<p>Esto genera un grafo regular en forma de árbol con 127 vértices, cada
vértice con dos hijos. No importa cuántas veces llames a
<code>make_tree()</code>, el grafo generado será siempre el mismo si
utilizas los mismos parámetros:</p>
<div class="sourceCode" id="cb30"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb30-1"><a href="#cb30-1" tabindex="-1"></a>graph2 <span class="ot">&lt;-</span> <span class="fu">make_tree</span>(<span class="dv">127</span>, <span class="dv">2</span>, <span class="at">mode =</span> <span class="st">&quot;undirected&quot;</span>)</span></code></pre></div>
<div class="sourceCode" id="cb31"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb31-1"><a href="#cb31-1" tabindex="-1"></a><span class="fu">identical_graphs</span>(graph1, graph2)</span></code></pre></div>
<pre><code>## [1] TRUE</code></pre>
<p>Otras funciones son <em>estocásticas</em>, lo cual quiere decir que
producen un grafo diferente cada vez; por ejemplo,
<code>sample_grg()</code>:</p>
<div class="sourceCode" id="cb33"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb33-1"><a href="#cb33-1" tabindex="-1"></a>graph1 <span class="ot">&lt;-</span> <span class="fu">sample_grg</span>(<span class="dv">100</span>, <span class="fl">0.2</span>)</span>
<span id="cb33-2"><a href="#cb33-2" tabindex="-1"></a><span class="fu">summary</span>(graph1)</span></code></pre></div>
<pre><code>## IGRAPH f42d783 U--- 100 478 -- Geometric random graph
## + attr: name (g/c), radius (g/n), torus (g/l)</code></pre>
<p>Esto genera un grafo geométrico aleatorio: Se eligen <em>n</em>
puntos de forma aleatoria y uniforme dentro del espacio métrico, y los
pares de puntos más cercanos entre sí respecto a una distancia
predeterminada <em>d</em> se conectan mediante una arista. Si se generan
GRGs con los mismos parámetros, serán diferentes:</p>
<div class="sourceCode" id="cb35"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb35-1"><a href="#cb35-1" tabindex="-1"></a>graph2 <span class="ot">&lt;-</span> <span class="fu">sample_grg</span>(<span class="dv">100</span>, <span class="fl">0.2</span>)</span>
<span id="cb35-2"><a href="#cb35-2" tabindex="-1"></a><span class="fu">identical_graphs</span>(graph1, graph2)</span></code></pre></div>
<pre><code>## [1] FALSE</code></pre>
<p>Una forma un poco más relajada de comprobar si los grafos son
equivalentes es mediante <code>isomorphic()</code>. Se dice que dos
grafos son isomorfos si tienen el mismo número de componentes (vértices
y aristas) y mantienen una correspondencia uno a uno entre vértices y
aristas, es decir, están conectados de la misma manera:</p>
<div class="sourceCode" id="cb37"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb37-1"><a href="#cb37-1" tabindex="-1"></a><span class="fu">isomorphic</span>(graph1, graph2)</span></code></pre></div>
<pre><code>## [1] FALSE</code></pre>
<p>Comprobar el isomorfismo puede llevar un tiempo en el caso de grafos
grandes (en este caso, la respuesta puede darse rápidamente comprobando
la secuencia de grados de los dos grafos).
<code>identical_graph()</code> es un criterio más estricto que
<code>isomorphic()</code>: los dos grafos deben tener la misma lista de
vértices y aristas, exactamente en el mismo orden, con la misma
direccionalidad, y los dos grafos también deben tener idénticos
atributos de grafo, vértice y arista.</p>
</div>
<div id="establecer-y-recuperar-atributos" class="section level2">
<h2>Establecer y recuperar atributos</h2>
<p>Además de los IDs, los vértices y aristas pueden tener
<em>atributos</em> como un nombre, coordenadas para graficar, metadatos
y pesos. El propio grafo también puede tener estos atributos (por
ejemplo, un nombre, que se mostrará en <code>summary</code>). En cierto
sentido, cada grafo, vértice y arista puede ser utilizado como un
espacio de nombres en R para almacenar y recuperar estos atributos.</p>
<p>Para demostrar el uso de los atributos, creemos una red social
sencilla:</p>
<div class="sourceCode" id="cb39"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb39-1"><a href="#cb39-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">make_graph</span>(</span>
<span id="cb39-2"><a href="#cb39-2" tabindex="-1"></a>  <span class="sc">~</span> Alice<span class="sc">-</span>Boris<span class="sc">:</span>Himari<span class="sc">:</span>Moshe,</span>
<span id="cb39-3"><a href="#cb39-3" tabindex="-1"></a>  Himari<span class="sc">-</span>Alice<span class="sc">:</span>Nang<span class="sc">:</span>Moshe<span class="sc">:</span>Samira,</span>
<span id="cb39-4"><a href="#cb39-4" tabindex="-1"></a>  Ibrahim<span class="sc">-</span>Nang<span class="sc">:</span>Moshe, </span>
<span id="cb39-5"><a href="#cb39-5" tabindex="-1"></a>  Nang<span class="sc">-</span>Samira</span>
<span id="cb39-6"><a href="#cb39-6" tabindex="-1"></a>)</span></code></pre></div>
<p>Cada vértice representa a una persona, por lo que queremos almacenar
sus edades, géneros y el tipo de conexión entre dos personas
(<code>is_formal()</code> se refiere a si una conexión entre una persona
y otra es formal o informal, es decir, colegas o amigos). El operador
<code>$</code> es un atajo para obtener y establecer atributos de un
grafo. Es más corto y tan legible como <code>graph_attr()</code> y
<code>set_graph_attr()</code>.</p>
<div class="sourceCode" id="cb40"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb40-1"><a href="#cb40-1" tabindex="-1"></a><span class="fu">V</span>(g)<span class="sc">$</span>age <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="dv">25</span>, <span class="dv">31</span>, <span class="dv">18</span>, <span class="dv">23</span>, <span class="dv">47</span>, <span class="dv">22</span>, <span class="dv">50</span>) </span>
<span id="cb40-2"><a href="#cb40-2" tabindex="-1"></a><span class="fu">V</span>(g)<span class="sc">$</span>gender <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="st">&quot;f&quot;</span>, <span class="st">&quot;m&quot;</span>, <span class="st">&quot;f&quot;</span>, <span class="st">&quot;m&quot;</span>, <span class="st">&quot;m&quot;</span>, <span class="st">&quot;f&quot;</span>, <span class="st">&quot;m&quot;</span>)</span>
<span id="cb40-3"><a href="#cb40-3" tabindex="-1"></a><span class="fu">E</span>(g)<span class="sc">$</span>is_formal <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="cn">FALSE</span>, <span class="cn">FALSE</span>, <span class="cn">TRUE</span>, <span class="cn">TRUE</span>, <span class="cn">TRUE</span>, <span class="cn">FALSE</span>, <span class="cn">TRUE</span>, <span class="cn">FALSE</span>, <span class="cn">FALSE</span>)</span>
<span id="cb40-4"><a href="#cb40-4" tabindex="-1"></a><span class="fu">summary</span>(g)</span></code></pre></div>
<pre><code>## IGRAPH 965c8de UN-- 7 9 -- 
## + attr: name (v/c), age (v/n), gender (v/c), is_formal (e/l)</code></pre>
<p><code>V</code> y <code>E</code> son la forma estándar de obtener una
secuencia de todos los vértices y aristas respectivamente. Esto asigna
un atributo a <em>todos</em> los vértices/aristas a la vez. Otra forma
de generar nuestra red social es con el uso de
<code>set_vertex_attr()</code> y <code>set_edge_attr()</code> y el
operador <code>%&gt;%</code>:</p>
<div class="sourceCode" id="cb42"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb42-1"><a href="#cb42-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">make_graph</span>(</span>
<span id="cb42-2"><a href="#cb42-2" tabindex="-1"></a>  <span class="sc">~</span> Alice<span class="sc">-</span>Boris<span class="sc">:</span>Himari<span class="sc">:</span>Moshe, </span>
<span id="cb42-3"><a href="#cb42-3" tabindex="-1"></a>  Himari<span class="sc">-</span>Alice<span class="sc">:</span>Nang<span class="sc">:</span>Moshe<span class="sc">:</span>Samira,</span>
<span id="cb42-4"><a href="#cb42-4" tabindex="-1"></a>  Ibrahim<span class="sc">-</span>Nang<span class="sc">:</span>Moshe, </span>
<span id="cb42-5"><a href="#cb42-5" tabindex="-1"></a>  Nang<span class="sc">-</span>Samira</span>
<span id="cb42-6"><a href="#cb42-6" tabindex="-1"></a>) <span class="sc">%&gt;%</span></span>
<span id="cb42-7"><a href="#cb42-7" tabindex="-1"></a>  <span class="fu">set_vertex_attr</span>(<span class="st">&quot;age&quot;</span>, <span class="at">value =</span> <span class="fu">c</span>(<span class="dv">25</span>, <span class="dv">31</span>, <span class="dv">18</span>, <span class="dv">23</span>, <span class="dv">47</span>, <span class="dv">22</span>, <span class="dv">50</span>)) <span class="sc">%&gt;%</span></span>
<span id="cb42-8"><a href="#cb42-8" tabindex="-1"></a>  <span class="fu">set_vertex_attr</span>(<span class="st">&quot;gender&quot;</span>, <span class="at">value =</span> <span class="fu">c</span>(<span class="st">&quot;f&quot;</span>, <span class="st">&quot;m&quot;</span>, <span class="st">&quot;f&quot;</span>, <span class="st">&quot;m&quot;</span>, <span class="st">&quot;m&quot;</span>, <span class="st">&quot;f&quot;</span>, <span class="st">&quot;m&quot;</span>)) <span class="sc">%&gt;%</span></span>
<span id="cb42-9"><a href="#cb42-9" tabindex="-1"></a>  <span class="fu">set_edge_attr</span>(<span class="st">&quot;is_formal&quot;</span>, <span class="at">value =</span> <span class="fu">c</span>(<span class="cn">FALSE</span>, <span class="cn">FALSE</span>, <span class="cn">TRUE</span>, <span class="cn">TRUE</span>, <span class="cn">TRUE</span>, <span class="cn">FALSE</span>, <span class="cn">TRUE</span>, <span class="cn">FALSE</span>, <span class="cn">FALSE</span>))</span>
<span id="cb42-10"><a href="#cb42-10" tabindex="-1"></a><span class="fu">summary</span>(g)</span></code></pre></div>
<p>Para asignar o modificar un atributo a un único vértice/arista:</p>
<div class="sourceCode" id="cb43"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb43-1"><a href="#cb43-1" tabindex="-1"></a><span class="fu">E</span>(g)<span class="sc">$</span>is_formal</span></code></pre></div>
<pre><code>## [1] FALSE FALSE  TRUE  TRUE  TRUE FALSE  TRUE FALSE FALSE</code></pre>
<div class="sourceCode" id="cb45"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb45-1"><a href="#cb45-1" tabindex="-1"></a><span class="fu">E</span>(g)<span class="sc">$</span>is_formal[<span class="dv">1</span>] <span class="ot">&lt;-</span> <span class="cn">TRUE</span></span>
<span id="cb45-2"><a href="#cb45-2" tabindex="-1"></a><span class="fu">E</span>(g)<span class="sc">$</span>is_formal</span></code></pre></div>
<pre><code>## [1]  TRUE FALSE  TRUE  TRUE  TRUE FALSE  TRUE FALSE FALSE</code></pre>
<p>Los valores de los atributos pueden establecerse en cualquier objeto
de R, pero ten en cuenta que almacenar el grafo en algunos formatos
puede provocar la pérdida de valores en atributos complejos. Los
vértices, las aristas y el propio grafo pueden utilizarse para
establecer atributos, por ejemplo, para añadir una fecha al grafo:</p>
<div class="sourceCode" id="cb47"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb47-1"><a href="#cb47-1" tabindex="-1"></a>g<span class="sc">$</span>date <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="st">&quot;2022-02-11&quot;</span>)</span>
<span id="cb47-2"><a href="#cb47-2" tabindex="-1"></a><span class="fu">graph_attr</span>(g, <span class="st">&quot;date&quot;</span>)</span></code></pre></div>
<pre><code>## [1] &quot;2022-02-11&quot;</code></pre>
<p>Para recuperar atributos, también puedes utilizar
<code>graph_attr()</code>, <code>vertex_attr()</code> y
<code>edge_attr()</code>. Para encontrar el ID de un vértice puedes
utilizar la función <code>match()</code>:</p>
<div class="sourceCode" id="cb49"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb49-1"><a href="#cb49-1" tabindex="-1"></a><span class="fu">match</span>(<span class="fu">c</span>(<span class="st">&quot;Ibrahim&quot;</span>), <span class="fu">V</span>(g)<span class="sc">$</span>name)</span></code></pre></div>
<pre><code>## [1] 7</code></pre>
<p>Para asignar atributos a un subconjunto de vértices o aristas, puedes
utilizar:</p>
<div class="sourceCode" id="cb51"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb51-1"><a href="#cb51-1" tabindex="-1"></a><span class="fu">V</span>(g)<span class="sc">$</span>name[<span class="dv">1</span><span class="sc">:</span><span class="dv">3</span>] <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="st">&quot;Alejandra&quot;</span>, <span class="st">&quot;Bruno&quot;</span>, <span class="st">&quot;Carmina&quot;</span>)</span>
<span id="cb51-2"><a href="#cb51-2" tabindex="-1"></a><span class="fu">V</span>(g)</span></code></pre></div>
<pre><code>## + 7/7 vertices, named, from 965c8de:
## [1] Alejandra Bruno     Carmina   Moshe     Nang      Samira    Ibrahim</code></pre>
<p>Para eliminar atributos:</p>
<div class="sourceCode" id="cb53"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb53-1"><a href="#cb53-1" tabindex="-1"></a>g <span class="ot">&lt;-</span> <span class="fu">delete_vertex_attr</span>(g, <span class="st">&quot;gender&quot;</span>)</span>
<span id="cb53-2"><a href="#cb53-2" tabindex="-1"></a><span class="fu">V</span>(g)<span class="sc">$</span>gender</span></code></pre></div>
<pre><code>## NULL</code></pre>
<p>Si quieres guardar un grafo en R con todos los atributos utiliza la
función estándar de R <code>dput</code> y recupéralo más tarde con
<code>dget</code>. También puedes simplemente guardar el espacio de
trabajo de R y restaurarlo más tarde.</p>
</div>
<div id="propiedades-estructurales-de-los-grafos" class="section level2">
<h2>Propiedades estructurales de los grafos</h2>
<p>igraph proporciona un amplio conjunto de métodos para calcular varias
propiedades estructurales de los grafos. Está más allá del alcance de
este tutorial documentar todos ellos, por lo que esta sección sólo
presentará algunos de ellos con fines ilustrativos. Trabajaremos con la
pequeña red social que construimos en la sección anterior.</p>
<p>Probablemente, la propiedad más sencilla en la que se puede pensar es
el “grado del vértice”. El grado de un vértice es igual al número de
aristas incidentes a él. En el caso de los grafos dirigidos, también
podemos definir el <code>grado de entrada</code> (el número de aristas
que apuntan hacia el vértice) y el <code>grado de salida</code> (el
número de aristas que se originan en el vértice). igraph es capaz de
calcularlos todos utilizando una sintaxis sencilla:</p>
<div class="sourceCode" id="cb55"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb55-1"><a href="#cb55-1" tabindex="-1"></a><span class="fu">degree</span>(g)</span></code></pre></div>
<pre><code>## Alejandra     Bruno   Carmina     Moshe      Nang    Samira   Ibrahim 
##         3         1         4         3         3         2         2</code></pre>
<p>Si el grafo fuera dirigido, podríamos calcular los grados de entrada
y salida por separado utilizando <code>degree(mode = &quot;in&quot;)</code> y
<code>degree(mode = &quot;out&quot;)</code>. También puedes pasar un único ID de
un vértice o una lista de IDs de los vértices a <code>degree()</code> si
quieres calcular los grados sólo para un subconjunto de vértices:</p>
<div class="sourceCode" id="cb57"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb57-1"><a href="#cb57-1" tabindex="-1"></a><span class="fu">degree</span>(g, <span class="dv">7</span>)</span></code></pre></div>
<pre><code>## Ibrahim 
##       2</code></pre>
<div class="sourceCode" id="cb59"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb59-1"><a href="#cb59-1" tabindex="-1"></a><span class="fu">degree</span>(g, <span class="at">v =</span> <span class="fu">c</span>(<span class="dv">3</span>,<span class="dv">4</span>,<span class="dv">5</span>))</span></code></pre></div>
<pre><code>## Carmina   Moshe    Nang 
##       4       3       3</code></pre>
<p>La mayoría de las funciones que aceptan los IDs de los vértices
también aceptan los “nombres” de los vértices (es decir, los valores del
atributo <code>name</code> del vértice) siempre que los nombres sean
únicos:</p>
<div class="sourceCode" id="cb61"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb61-1"><a href="#cb61-1" tabindex="-1"></a><span class="fu">degree</span>(g, <span class="at">v =</span> <span class="fu">c</span>(<span class="st">&quot;Carmina&quot;</span>, <span class="st">&quot;Moshe&quot;</span>, <span class="st">&quot;Nang&quot;</span>))</span></code></pre></div>
<pre><code>## Carmina   Moshe    Nang 
##       4       3       3</code></pre>
<p>También funciona para vértices individuales:</p>
<div class="sourceCode" id="cb63"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb63-1"><a href="#cb63-1" tabindex="-1"></a><span class="fu">degree</span>(g, <span class="st">&quot;Bruno&quot;</span>)</span></code></pre></div>
<pre><code>## Bruno 
##     1</code></pre>
<p>De igual manera, se utiliza una sintaxis similar para la mayoría de
las propiedades estructurales que igraph puede calcular. Para las
propiedades de los vértices, las funciones aceptan un ID, un nombre o
una lista de IDs o nombres (y si se omiten, el valor predeterminado es
el conjunto de todos los vértices). Para las propiedades de aristas, las
funciones aceptan un único ID o una lista de IDs.</p>
<hr />
<p><strong>NOTA:</strong> Para algunas mediciones, no tiene sentido
calcularlas sólo para unos pocos vértices o aristas en lugar de para
todo el grafo, ya que de todas formas llevaría el mismo tiempo. En este
caso, las funciones no aceptan IDs de vértices o aristas, pero se puede
restringir la lista resultante utilizando operaciones estándar. Un
ejemplo es la centralidad de vectores propios
(<code>evcent()</code>).</p>
<hr />
<p>Además del grado, igraph incluye funciones integradas para calcular
muchas otras propiedades de centralidad, como la intermediación de
vértices y aristas (<code>edge_betweenness()</code>) o el PageRank de
Google (<code>page_rank()</code>), por nombrar algunas. Aquí sólo
ilustraremos la intermediación de aristas:</p>
<div class="sourceCode" id="cb65"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb65-1"><a href="#cb65-1" tabindex="-1"></a><span class="fu">edge_betweenness</span>(g)</span></code></pre></div>
<pre><code>## [1] 6 6 4 3 4 4 4 2 3</code></pre>
<p>De este modo, ahora también podemos averiguar qué conexiones tienen
la mayor centralidad de intermediación:</p>
<div class="sourceCode" id="cb67"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb67-1"><a href="#cb67-1" tabindex="-1"></a>ebs <span class="ot">&lt;-</span> <span class="fu">edge_betweenness</span>(g)</span>
<span id="cb67-2"><a href="#cb67-2" tabindex="-1"></a><span class="fu">as_edgelist</span>(g)[ebs <span class="sc">==</span> <span class="fu">max</span>(ebs), ]</span></code></pre></div>
<pre><code>##      [,1]        [,2]     
## [1,] &quot;Alejandra&quot; &quot;Bruno&quot;  
## [2,] &quot;Alejandra&quot; &quot;Carmina&quot;</code></pre>
</div>
<div id="búsqueda-de-vértices-y-aristas-basada-en-atributos" class="section level2">
<h2>Búsqueda de vértices y aristas basada en atributos</h2>
<div id="selección-de-vértices" class="section level3">
<h3>Selección de vértices</h3>
<p>Tomando como ejemplo la red social anteriormente creada, te gustaría
averiguar quién tiene el mayor grado. Puedes hacerlo con las
herramientas presentadas hasta ahora y con la función
<code>which.max()</code>:</p>
<div class="sourceCode" id="cb69"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb69-1"><a href="#cb69-1" tabindex="-1"></a><span class="fu">which.max</span>(<span class="fu">degree</span>(g))</span></code></pre></div>
<pre><code>## Carmina 
##       3</code></pre>
<p>Otro ejemplo sería seleccionar sólo los vértices que tienen IDs
impares, utilizando la función <code>V()</code>:</p>
<div class="sourceCode" id="cb71"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb71-1"><a href="#cb71-1" tabindex="-1"></a>graph <span class="ot">&lt;-</span> <span class="fu">graph.full</span>(<span class="at">n=</span><span class="dv">10</span>)</span>
<span id="cb71-2"><a href="#cb71-2" tabindex="-1"></a>only_odd_vertices <span class="ot">&lt;-</span> <span class="fu">which</span>(<span class="fu">V</span>(graph)<span class="sc">%%</span><span class="dv">2</span><span class="sc">==</span><span class="dv">1</span>)</span>
<span id="cb71-3"><a href="#cb71-3" tabindex="-1"></a><span class="fu">length</span>(only_odd_vertices)</span></code></pre></div>
<pre><code>## [1] 5</code></pre>
<p>Por supuesto, es posible seleccionar vértices o aristas mediante
índices posicionales:</p>
<div class="sourceCode" id="cb73"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb73-1"><a href="#cb73-1" tabindex="-1"></a>seq <span class="ot">&lt;-</span> <span class="fu">V</span>(graph)[<span class="dv">2</span>, <span class="dv">3</span>, <span class="dv">7</span>]</span>
<span id="cb73-2"><a href="#cb73-2" tabindex="-1"></a>seq</span></code></pre></div>
<pre><code>## + 3/10 vertices, from 6cad540:
## [1] 2 3 7</code></pre>
<div class="sourceCode" id="cb75"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb75-1"><a href="#cb75-1" tabindex="-1"></a>seq <span class="ot">&lt;-</span> seq[<span class="dv">1</span>, <span class="dv">3</span>]    <span class="co"># filtrar un conjunto de vértices existente</span></span>
<span id="cb75-2"><a href="#cb75-2" tabindex="-1"></a>seq</span></code></pre></div>
<pre><code>## + 2/10 vertices, from 6cad540:
## [1] 2 7</code></pre>
<p>Al seleccionar un vértice que no existe se produce un error:</p>
<div class="sourceCode" id="cb77"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb77-1"><a href="#cb77-1" tabindex="-1"></a>seq <span class="ot">&lt;-</span> <span class="fu">V</span>(graph)[<span class="dv">2</span>, <span class="dv">3</span>, <span class="dv">7</span>, <span class="st">&quot;foo&quot;</span>, <span class="fl">3.5</span>]</span></code></pre></div>
<pre><code>## Error in simple_vs_index(x, ii, na_ok): Unknown vertex selected</code></pre>
<p>Los nombres de los atributos también pueden utilizarse tal cual
dentro de los operadores de indexación (“[]”) de <code>V()</code> y
<code>E()</code>. Esto puede combinarse con la capacidad de R de
utilizar vectores booleanos para indexar y obtener expresiones muy
concisas y legibles para recuperar un subconjunto del set de vértices o
aristas de un grafo. Por ejemplo, el siguiente comando nos da los
nombres de los individuos menores de 30 años de nuestra red social:</p>
<div class="sourceCode" id="cb79"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb79-1"><a href="#cb79-1" tabindex="-1"></a><span class="fu">V</span>(g)[age <span class="sc">&lt;</span> <span class="dv">30</span>]<span class="sc">$</span>name</span></code></pre></div>
<pre><code>## [1] &quot;Alejandra&quot; &quot;Carmina&quot;   &quot;Moshe&quot;     &quot;Samira&quot;</code></pre>
<p>Por supuesto, <code>&lt;</code> no es el único operador booleano que
puede utilizarse para esto. Otras posibilidades son las siguientes:</p>
<table>
<colgroup>
<col width="13%" />
<col width="86%" />
</colgroup>
<thead>
<tr class="header">
<th>Operador</th>
<th>Significado</th>
</tr>
</thead>
<tbody>
<tr class="odd">
<td><code>==</code></td>
<td>El valor del atributo/propiedad debe ser <em>igual</em> a</td>
</tr>
<tr class="even">
<td><code>!=</code></td>
<td>El valor del atributo/propiedad debe <em>no ser igual</em> a</td>
</tr>
<tr class="odd">
<td><code>&lt;</code></td>
<td>El valor del atributo/propiedad debe ser <em>menos</em> que</td>
</tr>
<tr class="even">
<td><code>&lt;=</code></td>
<td>El valor del atributo/propiedad debe ser <em>inferior o igual
a</em></td>
</tr>
<tr class="odd">
<td><code>&gt;</code></td>
<td>El valor del atributo/propiedad debe ser <em>mayor que</em></td>
</tr>
<tr class="even">
<td><code>&gt;=</code></td>
<td>El valor del atributo/propiedad debe ser <em>mayor o igual
a</em></td>
</tr>
<tr class="odd">
<td><code>%in%</code></td>
<td>El valor del atributo/propiedad debe estar <em>incluido en</em></td>
</tr>
</tbody>
</table>
<p>También puede crear un operador “no incluido en” a partir de
<code>%in%</code> utilizando el operador <code>Negate</code>:</p>
<div class="sourceCode" id="cb81"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb81-1"><a href="#cb81-1" tabindex="-1"></a><span class="st">`</span><span class="at">%notin%</span><span class="st">`</span> <span class="ot">&lt;-</span> <span class="fu">Negate</span>(<span class="st">`</span><span class="at">%in%</span><span class="st">`</span>)</span></code></pre></div>
<p>Si un atributo tiene el mismo nombre que una función de igraph, debes
tener cuidado ya que la sintaxis puede llegar a ser un poco confusa. Por
ejemplo, si hay un atributo llamado <code>degree</code> que representa
las notas de un examen para cada persona, no debe confundirse con la
función de igraph que calcula los grados de los vértices de una red:</p>
<div class="sourceCode" id="cb82"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb82-1"><a href="#cb82-1" tabindex="-1"></a><span class="fu">V</span>(g)<span class="sc">$</span>degree <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="st">&quot;A&quot;</span>, <span class="st">&quot;B&quot;</span>, <span class="st">&quot;B+&quot;</span>, <span class="st">&quot;A+&quot;</span>, <span class="st">&quot;C&quot;</span>, <span class="st">&quot;A&quot;</span>, <span class="st">&quot;B&quot;</span>)</span>
<span id="cb82-2"><a href="#cb82-2" tabindex="-1"></a><span class="fu">V</span>(g)<span class="sc">$</span>degree[<span class="fu">degree</span>(g) <span class="sc">==</span> <span class="dv">3</span>]</span></code></pre></div>
<pre><code>## [1] &quot;A&quot;  &quot;A+&quot; &quot;C&quot;</code></pre>
<div class="sourceCode" id="cb84"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb84-1"><a href="#cb84-1" tabindex="-1"></a><span class="fu">V</span>(g)<span class="sc">$</span>name[<span class="fu">degree</span>(g) <span class="sc">==</span> <span class="dv">3</span>]</span></code></pre></div>
<pre><code>## [1] &quot;Alejandra&quot; &quot;Moshe&quot;     &quot;Nang&quot;</code></pre>
</div>
<div id="selección-de-aristas" class="section level3">
<h3>Selección de aristas</h3>
<p>Las aristas pueden seleccionarse basándose en atributos, igual que
los vértices. Como ya se ha mencionado, la forma estándar de obtener
aristas es <code>E</code>. Además, existen algunas propiedades
estructurales especiales para seleccionar aristas.</p>
<p>El uso de <code>.from()</code> permite filtrar la serie de aristas
desde los vértices de donde proceden. Por ejemplo, para seleccionar
todas las aristas procedentes de Carmina (cuyo ID de vértice es el
3):</p>
<div class="sourceCode" id="cb86"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb86-1"><a href="#cb86-1" tabindex="-1"></a><span class="fu">E</span>(g)[<span class="fu">.from</span>(<span class="dv">3</span>)]</span></code></pre></div>
<pre><code>## + 4/9 edges from 965c8de (vertex names):
## [1] Alejandra--Carmina Carmina  --Moshe   Carmina  --Nang    Carmina  --Samira</code></pre>
<p>Por supuesto, también funciona con nombres de vértices:</p>
<div class="sourceCode" id="cb88"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb88-1"><a href="#cb88-1" tabindex="-1"></a><span class="fu">E</span>(g)[<span class="fu">.from</span>(<span class="st">&quot;Carmina&quot;</span>)]</span></code></pre></div>
<pre><code>## + 4/9 edges from 965c8de (vertex names):
## [1] Alejandra--Carmina Carmina  --Moshe   Carmina  --Nang    Carmina  --Samira</code></pre>
<p>Al usar <code>.to()</code>, se filtran la serie de aristas en función
de los vértices de destino o diana. Esto es diferente de
<code>.from()</code> si el grafo es dirigido, mientras que da la misma
respuesta para grafos no dirigidos. Con <code>.inc()</code> sólo se
seleccionan las aristas que inciden en un único vértice o en al menos
uno de los vértices, independientemente de la dirección de las
aristas.</p>
<p>La expresión <code>%--%</code> es un operador especial que puede
utilizarse para seleccionar todas las aristas entre dos conjuntos de
vértices. Ignora las direcciones de las aristas en los grafos dirigidos.
Por ejemplo, la siguiente expresión selecciona todas las aristas entre
Carmina (su ID de vértice es el 3), Nang (su ID de vértice es el 5) y
Samira (su ID de vértice es el 6):</p>
<div class="sourceCode" id="cb90"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb90-1"><a href="#cb90-1" tabindex="-1"></a><span class="fu">E</span>(g) [ <span class="dv">3</span><span class="sc">:</span><span class="dv">5</span> <span class="sc">%--%</span> <span class="dv">5</span><span class="sc">:</span><span class="dv">6</span> ]</span></code></pre></div>
<pre><code>## + 3/9 edges from 965c8de (vertex names):
## [1] Carmina--Nang   Carmina--Samira Nang   --Samira</code></pre>
<p>Para que el operador <code>%--%</code> funcione con nombres, puedes
construir vectores de caracteres que contengan los nombres y luego
utilizar estos vectores como operandos. Por ejemplo, para seleccionar
todas las aristas que conectan a los hombres con las mujeres, podemos
hacer lo siguiente, luego de volver a añadir el atributo de género que
hemos eliminado anteriormente:</p>
<div class="sourceCode" id="cb92"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb92-1"><a href="#cb92-1" tabindex="-1"></a><span class="fu">V</span>(g)<span class="sc">$</span>gender <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="st">&quot;f&quot;</span>, <span class="st">&quot;m&quot;</span>, <span class="st">&quot;f&quot;</span>, <span class="st">&quot;m&quot;</span>, <span class="st">&quot;m&quot;</span>, <span class="st">&quot;f&quot;</span>, <span class="st">&quot;m&quot;</span>)</span></code></pre></div>
<div class="sourceCode" id="cb93"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb93-1"><a href="#cb93-1" tabindex="-1"></a>men <span class="ot">&lt;-</span> <span class="fu">V</span>(g)[gender <span class="sc">==</span> <span class="st">&quot;m&quot;</span>]<span class="sc">$</span>name</span>
<span id="cb93-2"><a href="#cb93-2" tabindex="-1"></a>men</span></code></pre></div>
<pre><code>## [1] &quot;Bruno&quot;   &quot;Moshe&quot;   &quot;Nang&quot;    &quot;Ibrahim&quot;</code></pre>
<div class="sourceCode" id="cb95"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb95-1"><a href="#cb95-1" tabindex="-1"></a>women <span class="ot">&lt;-</span> <span class="fu">V</span>(g)[gender <span class="sc">==</span> <span class="st">&quot;f&quot;</span>]<span class="sc">$</span>name</span>
<span id="cb95-2"><a href="#cb95-2" tabindex="-1"></a>women</span></code></pre></div>
<pre><code>## [1] &quot;Alejandra&quot; &quot;Carmina&quot;   &quot;Samira&quot;</code></pre>
<div class="sourceCode" id="cb97"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb97-1"><a href="#cb97-1" tabindex="-1"></a><span class="fu">E</span>(g)[men <span class="sc">%--%</span> women]</span></code></pre></div>
<pre><code>## + 5/9 edges from 965c8de (vertex names):
## [1] Alejandra--Bruno  Alejandra--Moshe  Carmina  --Moshe  Carmina  --Nang  
## [5] Nang     --Samira</code></pre>
</div>
</div>
<div id="tratar-un-grafo-como-una-matriz-de-adyacencia" class="section level2">
<h2>Tratar un grafo como una matriz de adyacencia</h2>
<p>Una matriz de adyacencia es otra manera de representar un grafo. En
la matriz de adyacencia, las filas y columnas están indicadas por los
vértices del grafo y los elementos de la matriz indican el número de
aristas entre los vértices <em>i</em> y <em>j</em>. La matriz de
adyacencia del grafo de nuestra red social imaginaria es:</p>
<div class="sourceCode" id="cb99"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb99-1"><a href="#cb99-1" tabindex="-1"></a><span class="fu">as_adjacency_matrix</span>(g)</span></code></pre></div>
<pre><code>## 7 x 7 sparse Matrix of class &quot;dgCMatrix&quot;
##           Alejandra Bruno Carmina Moshe Nang Samira Ibrahim
## Alejandra         .     1       1     1    .      .       .
## Bruno             1     .       .     .    .      .       .
## Carmina           1     .       .     1    1      1       .
## Moshe             1     .       1     .    .      .       1
## Nang              .     .       1     .    .      1       1
## Samira            .     .       1     .    1      .       .
## Ibrahim           .     .       .     1    1      .       .</code></pre>
<p>Por ejemplo, Carmina (<code>1, 0, 0, 1, 1, 1, 0</code>) está
directamente conectada con Alejandra (que tiene el índice 1), Moshe
(índice 4), Nang (índice 5), Samira (índice 6) y , pero no con Bruno
(índice 2) ni con Ibrahim (índice 7).</p>
</div>
<div id="diseños-y-graficación" class="section level2">
<h2>Diseños y graficación</h2>
<p>Un grafo es un objeto matemático abstracto sin una representación
específica en el espacio 2D, 3D o cualquier espacio geométrico. Esto
significa que, cuando queremos visualizar un grafo, primero tenemos que
encontrar una correspondencia entre los vértices y las coordenadas en un
espacio bidimensional o tridimensional, preferiblemente de una manera
útil y/o agradable a la vista. Una rama separada de la teoría de grafos,
denominada dibujo de grafos, trata de resolver este problema mediante
varios algoritmos de diseño de grafos. igraph implementa varios
algoritmos de diseño y también es capaz de dibujarlos en la pantalla o
en cualquier formato de salida que soporte el propio R.</p>
<div id="algoritmos-de-diseño" class="section level3">
<h3>Algoritmos de diseño</h3>
<p>Las funciones de diseño en igraph siempre empiezan por
<code>layout</code>. La siguiente tabla las resume:</p>
<table>
<colgroup>
<col width="23%" />
<col width="76%" />
</colgroup>
<thead>
<tr class="header">
<th>Nombre del método</th>
<th>Descripción del algoritmo</th>
</tr>
</thead>
<tbody>
<tr class="odd">
<td><code>layout_randomly</code></td>
<td>Coloca los vértices de forma totalmente aleatoria</td>
</tr>
<tr class="even">
<td><code>layout_in_circle</code></td>
<td>Disposición determinista que coloca los vértices en un círculo</td>
</tr>
<tr class="odd">
<td><code>layout_on_sphere</code></td>
<td>Disposición determinista que coloca los vértices de manera uniforme
en la superficie de una esfera</td>
</tr>
<tr class="even">
<td><code>layout_with_drl</code></td>
<td>El algoritmo DRL (<em>Distributed Recursive Layout</em>) para grafos
grandes</td>
</tr>
<tr class="odd">
<td><code>layout_with_fr</code></td>
<td>El algoritmo dirigido Fruchterman-Reingold</td>
</tr>
<tr class="even">
<td><code>layout_with_kk</code></td>
<td>El algoritmo dirigido Kamada-Kawai</td>
</tr>
<tr class="odd">
<td><code>layout_with_lgl</code></td>
<td>El algoritmo LGL (<em>Large Graph Layout</em>) para grafos
grandes</td>
</tr>
<tr class="even">
<td><code>layout_as_tree</code></td>
<td>Diseño de árbol de Reingold-Tilford, útil para grafos (casi)
arbóreos</td>
</tr>
<tr class="odd">
<td><code>layout_nicely</code></td>
<td>Algoritmo de diseño que elige automáticamente uno de los otros
algoritmos en función de determinadas propiedades del grafo</td>
</tr>
</tbody>
</table>
<p>Los algoritmos de diseño pueden ejecutarse directamente con un grafo
como primer argumento. Devolverán una matriz con dos columnas y tantas
filas como número de vértices del grafo; cada fila corresponderá a la
posición de un único vértice, ordenado según el ID del vértice. Algunos
algoritmos tienen una variante 3D; en este caso devuelven tres columnas
en lugar de 2.</p>
<div class="sourceCode" id="cb101"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb101-1"><a href="#cb101-1" tabindex="-1"></a>layout <span class="ot">&lt;-</span> <span class="fu">layout_with_kk</span>(g)</span></code></pre></div>
<p>Algunos algoritmos de diseño toman argumentos adicionales; por
ejemplo, cuando se diseña un grafo con la forma de un árbol, puede tener
sentido especificar qué vértice debe colocarse en la raíz del
diseño:</p>
<div class="sourceCode" id="cb102"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb102-1"><a href="#cb102-1" tabindex="-1"></a>layout <span class="ot">&lt;-</span> <span class="fu">layout_as_tree</span>(g, <span class="at">root =</span> <span class="dv">2</span>)</span></code></pre></div>
</div>
<div id="dibujar-un-grafo-utilizando-un-diseño" class="section level3">
<h3>Dibujar un grafo utilizando un diseño</h3>
<p>Podemos trazar nuestra red social imaginaria con el algoritmo de
diseño Kamada-Kawai de la siguiente manera:</p>
<div class="sourceCode" id="cb103"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb103-1"><a href="#cb103-1" tabindex="-1"></a>layout <span class="ot">&lt;-</span> <span class="fu">layout_with_kk</span>(g)</span></code></pre></div>
<div class="sourceCode" id="cb104"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb104-1"><a href="#cb104-1" tabindex="-1"></a><span class="fu">plot</span>(g, <span class="at">layout =</span> layout, <span class="at">main =</span> <span class="st">&quot;Red social con el algoritmo de diseño Kamada-Kawai&quot;</span>)</span></code></pre></div>
<p><img role="img" src="" /><!-- --></p>
<p>Esto debería abrir una nueva ventana mostrando una representación
visual de la red. Recuerda que la ubicación exacta de los nodos puede
ser diferente en tu máquina, ya que la disposición no es
determinista.</p>
<p>El argumento <code>layout</code> también acepta funciones; en este
caso, la función será llamada con el grafo como su primer argumento.
Esto permite ingresar directamente el nombre de una función de diseño,
sin tener que crear una variable de diseño, como en el ejemplo
anterior:</p>
<div class="sourceCode" id="cb105"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb105-1"><a href="#cb105-1" tabindex="-1"></a><span class="fu">plot</span>(</span>
<span id="cb105-2"><a href="#cb105-2" tabindex="-1"></a>  g, </span>
<span id="cb105-3"><a href="#cb105-3" tabindex="-1"></a>  <span class="at">layout =</span> layout_with_fr,</span>
<span id="cb105-4"><a href="#cb105-4" tabindex="-1"></a>  <span class="at">main =</span> <span class="st">&quot;Red social con el algoritmo de disposición Fruchterman-Reingold&quot;</span></span>
<span id="cb105-5"><a href="#cb105-5" tabindex="-1"></a>)</span></code></pre></div>
<p><img role="img" src="" /><!-- --></p>
<p>Para mejorar el aspecto visual, una adición trivial sería colorear
los vértices según el género. También deberíamos intentar colocar los
nombres ligeramente fuera de los vértices para mejorar la
legibilidad:</p>
<div class="sourceCode" id="cb106"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb106-1"><a href="#cb106-1" tabindex="-1"></a><span class="fu">V</span>(g)<span class="sc">$</span>color <span class="ot">&lt;-</span> <span class="fu">ifelse</span>(<span class="fu">V</span>(g)<span class="sc">$</span>gender <span class="sc">==</span> <span class="st">&quot;m&quot;</span>, <span class="st">&quot;yellow&quot;</span>, <span class="st">&quot;red&quot;</span>)</span>
<span id="cb106-2"><a href="#cb106-2" tabindex="-1"></a><span class="fu">plot</span>(</span>
<span id="cb106-3"><a href="#cb106-3" tabindex="-1"></a>  g, </span>
<span id="cb106-4"><a href="#cb106-4" tabindex="-1"></a>  <span class="at">layout =</span> layout, </span>
<span id="cb106-5"><a href="#cb106-5" tabindex="-1"></a>  <span class="at">vertex.label.dist =</span> <span class="fl">3.5</span>,</span>
<span id="cb106-6"><a href="#cb106-6" tabindex="-1"></a>  <span class="at">main =</span> <span class="st">&quot;Red social - con los géneros como colores&quot;</span></span>
<span id="cb106-7"><a href="#cb106-7" tabindex="-1"></a>)</span></code></pre></div>
<p><img role="img" src="" /><!-- --></p>
<p>También puedes tratar el atributo <code>gender</code> como un factor
y proporcionar los colores como un argumento a <code>plot()</code>, que
tiene prioridad sobre el atributo <code>color</code> que se asigna de
manera estándar a los vértices. Los colores se asignan
automáticamente:</p>
<div class="sourceCode" id="cb107"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb107-1"><a href="#cb107-1" tabindex="-1"></a><span class="fu">plot</span>(</span>
<span id="cb107-2"><a href="#cb107-2" tabindex="-1"></a>  g, </span>
<span id="cb107-3"><a href="#cb107-3" tabindex="-1"></a>  <span class="at">layout =</span> layout, </span>
<span id="cb107-4"><a href="#cb107-4" tabindex="-1"></a>  <span class="at">vertex.label.dist =</span> <span class="fl">3.5</span>, </span>
<span id="cb107-5"><a href="#cb107-5" tabindex="-1"></a>  <span class="at">vertex.color =</span> <span class="fu">as.factor</span>(<span class="fu">V</span>(g)<span class="sc">$</span>gender))</span></code></pre></div>
<p><img role="img" src="" /><!-- --></p>
<p>Como se vio anteriormente, con el argumento <code>vertex.color</code>
puedes especificar propiedades visuales para <code>plot</code> en lugar
de usar y/o manipular los atributos de vértices o aristas. El siguiente
gráfico muestra las relaciones formales con líneas gruesas y las
informales con líneas finas:</p>
<div class="sourceCode" id="cb108"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb108-1"><a href="#cb108-1" tabindex="-1"></a><span class="fu">plot</span>(</span>
<span id="cb108-2"><a href="#cb108-2" tabindex="-1"></a>  g,</span>
<span id="cb108-3"><a href="#cb108-3" tabindex="-1"></a>  <span class="at">layout =</span> layout,</span>
<span id="cb108-4"><a href="#cb108-4" tabindex="-1"></a>  <span class="at">vertex.label.dist =</span> <span class="fl">3.5</span>,</span>
<span id="cb108-5"><a href="#cb108-5" tabindex="-1"></a>  <span class="at">vertex.size =</span> <span class="dv">20</span>,</span>
<span id="cb108-6"><a href="#cb108-6" tabindex="-1"></a>  <span class="at">vertex.color =</span> <span class="fu">ifelse</span>(<span class="fu">V</span>(g)<span class="sc">$</span>gender <span class="sc">==</span> <span class="st">&quot;m&quot;</span>, <span class="st">&quot;yellow&quot;</span>, <span class="st">&quot;red&quot;</span>),</span>
<span id="cb108-7"><a href="#cb108-7" tabindex="-1"></a>  <span class="at">edge.width =</span> <span class="fu">ifelse</span>(<span class="fu">E</span>(g)<span class="sc">$</span>is_formal, <span class="dv">5</span>, <span class="dv">1</span>)</span>
<span id="cb108-8"><a href="#cb108-8" tabindex="-1"></a>)</span></code></pre></div>
<p><img role="img" src="" /><!-- --></p>
<p>Este último procedimiento es preferible si quieres modificar la
representación visual de tu grafo, pero no quieres hacer modificaciones
al grafo mismo.</p>
<p>En resumen, hay propiedades especiales de vértices y aristas que
corresponden a la representación visual del grafo. Estos atributos
pueden modificar la configuración predeterminada de igraph (es decir,
color, peso, nombre, forma, diseño, etc.). Las dos tablas siguientes
resumen los atributos visuales más utilizados para vértices y aristas,
respectivamente:</p>
</div>
<div id="atributos-de-los-vértices-para-graficar" class="section level3">
<h3>Atributos de los vértices para graficar</h3>
<table>
<colgroup>
<col width="23%" />
<col width="23%" />
<col width="53%" />
</colgroup>
<thead>
<tr class="header">
<th>Nombre del atributo</th>
<th>Argumento</th>
<th>Propósito</th>
</tr>
</thead>
<tbody>
<tr class="odd">
<td><code>color</code></td>
<td><code>vertex.color</code></td>
<td>Color del vértice</td>
</tr>
<tr class="even">
<td><code>label</code></td>
<td><code>vertex.label</code></td>
<td>Etiqueta del vértice. Se convertirán en caracteres. Especifique NA
para omitir las etiquetas de los vértices. Las etiquetas de vértices por
defecto son los IDs de los vértices.</td>
</tr>
<tr class="odd">
<td><code>label.cex</code></td>
<td><code>vertex.label.cex</code></td>
<td>Tamaño de fuente de la etiqueta del vértice, interpretado como un
factor multiplicativo, de forma similar a la función <code>text</code>
de R</td>
</tr>
<tr class="even">
<td><code>label.color</code></td>
<td><code>vertex.label.color</code></td>
<td>Color de la etiqueta del vértice</td>
</tr>
<tr class="odd">
<td><code>label.degree</code></td>
<td><code>vertex.label.degree</code></td>
<td>Define la posición de las etiquetas de los vértices, en relación con
el centro de los mismos. Se interpreta como un ángulo en radianes, cero
significa ‘a la derecha’, y ‘pi’ significa a la izquierda, arriba es
-pi/2 y abajo es pi/2. El valor por defecto es -pi/4</td>
</tr>
<tr class="even">
<td><code>label.dist</code></td>
<td><code>vertex.label.dist</code></td>
<td>Distancia de la etiqueta del vértice desde el propio vértice, en
relación con el tamaño del vértice</td>
</tr>
<tr class="odd">
<td><code>label.family</code></td>
<td><code>vertex.label.family</code></td>
<td>Familia tipográfica del vértice, de forma similar a la función
<code>text</code> de R</td>
</tr>
<tr class="even">
<td><code>label.font</code></td>
<td><code>vertex.label.font</code></td>
<td>Fuente dentro de la familia de fuentes del vértice, de forma similar
a la función <code>text</code> de R</td>
</tr>
<tr class="odd">
<td><code>shape</code></td>
<td><code>vertex.shape</code></td>
<td>La forma del vértice, actualmente “circle”, “square”, “csquare”,
“rectangle”, “crectangle”, “vrectangle”, “pie” (consultar
<code>vertex.shape.pie</code>), ‘sphere’ y “none” son admitidos, y sólo
por el comando <code>plot.igraph</code></td>
</tr>
<tr class="even">
<td><code>size</code></td>
<td><code>vertex.size</code></td>
<td>El tamaño del vértice, un escalar numérico o vector, en este último
caso el tamaño de cada vértice puede ser diferente</td>
</tr>
</tbody>
</table>
</div>
<div id="atributos-de-las-aristas-para-graficar" class="section level3">
<h3>Atributos de las aristas para graficar</h3>
<table>
<colgroup>
<col width="34%" />
<col width="40%" />
<col width="25%" />
</colgroup>
<thead>
<tr class="header">
<th>Nombre del atributo</th>
<th>Argumento</th>
<th>Propósito</th>
</tr>
</thead>
<tbody>
<tr class="odd">
<td><code>color</code></td>
<td><code>edge.color</code></td>
<td>Color de la arista</td>
</tr>
<tr class="even">
<td><code>curved</code></td>
<td><code>edge.curved</code></td>
<td>Un valor numérico especifica la curvatura de la arista; una
curvatura cero significa aristas rectas, valores negativos significan
que la arista se curva en el sentido de las agujas del reloj, valores
positivos lo contrario. TRUE significa curvatura 0.5, FALSE significa
curvatura cero</td>
</tr>
<tr class="odd">
<td><code>arrow.size</code></td>
<td><code>edge.arrow.size</code></td>
<td>Actualmente es una constante, por lo que es la misma para todas las
aristas. Si se presenta un vector, sólo se utiliza el primer elemento,
es decir, si se toma de un atributo de aristas, sólo se utiliza el
atributo de la primera arista para todas las flechas</td>
</tr>
<tr class="even">
<td><code>arrow.width</code></td>
<td><code>edge.arrow.width</code></td>
<td>El ancho de las flechas. Actualmente es una constante, por lo que es
la misma para todas las aristas</td>
</tr>
<tr class="odd">
<td><code>width</code></td>
<td><code>edge.width</code></td>
<td>Anchura del borde en píxeles</td>
</tr>
<tr class="even">
<td><code>label</code></td>
<td><code>edge.label</code></td>
<td>Si se especifica, añade una etiqueta al borde</td>
</tr>
<tr class="odd">
<td><code>label.cex</code></td>
<td><code>edge.label.cex</code></td>
<td>Tamaño de fuente de la etiqueta de la arista, interpretado como un
factor multiplicativo, de forma similar a la función <code>text</code>
de R</td>
</tr>
<tr class="even">
<td><code>label.color</code></td>
<td><code>edge.label.color</code></td>
<td>Color de la etiqueta de la arista</td>
</tr>
<tr class="odd">
<td><code>label.family</code></td>
<td><code>edge.label.family</code></td>
<td>Familia tipográfica de la arista, de forma similar a la función
<code>text</code> de R</td>
</tr>
<tr class="even">
<td><code>label.font</code></td>
<td><code>edge.label.font</code></td>
<td>Fuente dentro de la familia de fuentes de la arista, de forma
similar a la función <code>text</code> de R</td>
</tr>
</tbody>
</table>
</div>
<div id="argumentos-más-comunes-de-plot" class="section level3">
<h3>Argumentos más comunes de <code>plot()</code></h3>
<p>Estos parámetros pueden especificarse como argumentos de la función
<code>plot</code> para ajustar el aspecto general del gráfico.</p>
<table>
<colgroup>
<col width="44%" />
<col width="55%" />
</colgroup>
<thead>
<tr class="header">
<th>Argumento</th>
<th>Propósito</th>
</tr>
</thead>
<tbody>
<tr class="odd">
<td><code>layout</code></td>
<td>El diseño que se va a utilizar. Puede ser una instancia de
<code>layout</code>, una lista de tuplas que contengan coordenadas X-Y,
o el nombre de un algoritmo de diseño. El valor por defecto es
<code>auto</code>, que selecciona un algoritmo de diseño automáticamente
basado en el tamaño y la conectividad del grafo.</td>
</tr>
<tr class="even">
<td><code>margin</code></td>
<td>La cantidad de espacio vacío debajo, encima, a la izquierda y a la
derecha del gráfico, es un vector numérico de longitud cuatro</td>
</tr>
</tbody>
</table>
</div>
</div>
<div id="igraph-y-el-mundo-exterior" class="section level2">
<h2>igraph y el mundo exterior</h2>
<p>Ningún módulo de grafos estaría completo sin algún tipo de
funcionalidad de importación/exportación que permita al paquete
comunicarse con programas y kits de herramientas externos. igraph no es
una excepción: proporciona funciones para leer los formatos de grafos
más comunes y para guardar grafos en archivos que obedezcan estas
especificaciones de formato. Las funciones principales para leer y
escribir de/a un fichero son <code>read_graph()</code> y
<code>write_graph()</code>, respectivamente. La siguiente tabla resume
los formatos que igraph puede leer o escribir:</p>
<table>
<colgroup>
<col width="23%" />
<col width="23%" />
<col width="26%" />
<col width="26%" />
</colgroup>
<thead>
<tr class="header">
<th>Formato</th>
<th>Nombre corto</th>
<th>Método de lectura</th>
<th>Método de escritura</th>
</tr>
</thead>
<tbody>
<tr class="odd">
<td>Lista de adyacencia (a.k.a. <a href="https://lgl.sourceforge.net/#FileFormat">LGL</a>)</td>
<td><code>lgl</code></td>
<td><code>read_graph(file, format = c(&quot;lgl&quot;))</code></td>
<td><code>write_graph(graph, file, format = c(&quot;lgl&quot;))</code></td>
</tr>
<tr class="even">
<td>Matriz de adyacencia</td>
<td><code>adjacency</code></td>
<td><code>graph_from_adjacency_matrix(adjmatrix, mode = c(&quot;directed&quot;, &quot;undirected&quot;, &quot;max&quot;, &quot;min&quot;, &quot;upper&quot;,&quot;lower&quot;, &quot;plus&quot;), weighted = NULL, diag = TRUE, add.colnames = NULL, add.rownames = NA)</code></td>
<td><code>as.matrix(graph, &quot;adjacency&quot;)</code></td>
</tr>
<tr class="odd">
<td>DIMACS</td>
<td><code>dimacs</code></td>
<td><code>read_graph(file, format = c(&quot;dimacs&quot;))</code></td>
<td><code>write_graph(graph, file, format = c(&quot;dimacs&quot;))</code></td>
</tr>
<tr class="even">
<td>Edge list</td>
<td><code>edgelist</code></td>
<td><code>read_graph(file, format = c(&quot;edgelist&quot;))</code></td>
<td><code>write_graph(graph, file, format = c(&quot;edgelist&quot;))</code></td>
</tr>
<tr class="odd">
<td><a href="https://www.graphviz.org">GraphViz</a></td>
<td><code>dot</code></td>
<td>not supported yet</td>
<td><code>write_graph(graph, file, format = c(&quot;dot&quot;))</code></td>
</tr>
<tr class="even">
<td>GML</td>
<td><code>gml</code></td>
<td><code>read_graph(file, format = c(&quot;gml&quot;))</code></td>
<td><code>write_graph(graph, file, format = c(&quot;gml&quot;))</code></td>
</tr>
<tr class="odd">
<td>GraphML</td>
<td><code>graphml</code></td>
<td><code>read_graph(file, format = c(&quot;graphml&quot;))</code></td>
<td><code>write_graph(graph, file, format = c(&quot;graphml&quot;))</code></td>
</tr>
<tr class="even">
<td>LEDA</td>
<td><code>leda</code></td>
<td>not supported yet</td>
<td><code>write_graph(graph, file, format = c(&quot;leda&quot;))</code></td>
</tr>
<tr class="odd">
<td>Labeled edgelist (a.k.a. <a href="https://lgl.sourceforge.net/#FileFormat">NCOL</a>)</td>
<td><code>ncol</code></td>
<td><code>read_graph(file, format = c(&quot;ncol&quot;))</code></td>
<td><code>write_graph(graph, file, format = c(&quot;ncol&quot;))</code></td>
</tr>
<tr class="even">
<td><a href="http://mrvar.fdv.uni-lj.si/pajek/">Pajek</a> format</td>
<td><code>pajek</code></td>
<td><code>read_graph(file, format = c(&quot;pajek&quot;))</code></td>
<td><code>write_graph(graph, file, format = c(&quot;pajek&quot;))</code></td>
</tr>
</tbody>
</table>
<hr />
<p><strong>NOTA:</strong> La mayoría de los formatos tienen sus propias
limitaciones; por ejemplo, no todos pueden almacenar atributos. Tu mejor
opción es probablemente GraphML o GML si quieres guardar los grafos de
igraph en un formato que pueda ser leído desde un paquete externo y
quieres preservar los atributos numéricos y de cadena. <em>Edge
list</em> y NCOL también están bien si no tienes atributos (aunque NCOL
admite nombres de vértices y pesos de aristas).</p>
<hr />
</div>
<div id="dónde-ir-a-continuación" class="section level2">
<h2>Dónde ir a continuación</h2>
<p>Este tutorial es una breve introducción a <code>igraph</code> en R.
Esperamos que hayas disfrutado de su lectura y que te resulte útil para
tus propios análisis de redes.</p>
<p>Para una descripción detallada de funciones específicas, consulta <a href="https://r.igraph.org/reference/" class="uri">https://r.igraph.org/reference/</a>. Si tienes preguntas
sobre cómo utilizar <code>igraph</code>, visita nuestro <a href="https://igraph.discourse.group">Foro</a>. Para informar de un
error, abre una <a href="https://github.com/igraph/rigraph/issues">incidencia en
Github</a>. Por favor, no hagas preguntas de uso en Github directamente,
ya que está pensado para desarrolladores y no para usuarios.</p>
</div>
<div id="información-de-la-sesión" class="section level2">
<h2>Información de la sesión</h2>
<p>En favor de la reproducibilidad, la información de la sesión para el
código anterior es la siguiente:</p>
<div class="sourceCode" id="cb109"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb109-1"><a href="#cb109-1" tabindex="-1"></a><span class="fu">sessionInfo</span>()</span></code></pre></div>
<pre><code>## R version 4.4.2 (2024-10-31)
## Platform: aarch64-apple-darwin20
## Running under: macOS Sequoia 15.2
## 
## Matrix products: default
## BLAS:   /Library/Frameworks/R.framework/Versions/4.4-arm64/Resources/lib/libRblas.0.dylib 
## LAPACK: /Library/Frameworks/R.framework/Versions/4.4-arm64/Resources/lib/libRlapack.dylib;  LAPACK version 3.12.0
## 
## locale:
## [1] C/en_US.UTF-8/en_US.UTF-8/C/en_US.UTF-8/en_US.UTF-8
## 
## time zone: Europe/Zurich
## tzcode source: internal
## 
## attached base packages:
## [1] stats     graphics  grDevices utils     datasets  methods   base     
## 
## other attached packages:
## [1] igraph_2.1.4
## 
## loaded via a namespace (and not attached):
##  [1] digest_0.6.37     R6_2.5.1          fastmap_1.2.0     Matrix_1.5-4.1   
##  [5] xfun_0.50         lattice_0.22-6    magrittr_2.0.3    glue_1.8.0       
##  [9] cachem_1.1.0      knitr_1.49        pkgconfig_2.0.3   htmltools_0.5.8.1
## [13] rmarkdown_2.29    lifecycle_1.0.4   cli_3.6.3         grid_4.4.2       
## [17] vctrs_0.6.5       sass_0.4.9        jquerylib_0.1.4   compiler_4.4.2   
## [21] rstudioapi_0.17.1 tools_4.4.2       pillar_1.10.1     evaluate_1.0.3   
## [25] bslib_0.8.0       yaml_2.3.10       crayon_1.5.3      rlang_1.1.5      
## [29] jsonlite_1.8.9</code></pre>
</div>



<!-- code folding -->


<!-- dynamically load mathjax for compatibility with self-contained -->
<script>
  (function () {
    var script = document.createElement("script");
    script.type = "text/javascript";
    script.src  = "https://mathjax.rstudio.com/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML";
    document.getElementsByTagName("head")[0].appendChild(script);
  })();
</script>

</body>
</html>