Зображення графа або мережевої діаграми — це графічне представлення вершин та ребер графа. Зображення не слід плутати з самим графом: зовні дуже різні зображення можуть відповідати одному і тому ж графу[2]. З точки зору теорії, все, що має значення — це які саме пари вершин з'єднуються ребрами. Однак, у конкретних ситуаціях, розташування вершин і ребер в межах малюнка впливає на його зрозумілість, зручність використання, вартість виготовлення та на естетичне сприйняття[3]. Задача стає більш складною, якщо граф змінюється з часом, коли додаються і видаляються ребра (зображення динамічного графа), або мета полягає у збереженні мапи думок користувача[4].
Домовленості
Графи зазвичай зображуються як діаграми, що наголошують на зв'язках між вузлами, де вершини представлені у вигляді дисків, коробок або текстових міток, і ребер, зображених відрізками, ламаними або кривими в евклідовому просторі[3]. Такі діаграми можна побачити у роботах 13-го століття Раймунда Луллія, які він використовував для зображення повних графів, з метою аналізу усіх попарних комбінацій для множини метафізичних понять[5].
У випадку орієнтованих графівстрілки вживаються для зазначення їх орієнтації[2]; Проте, дослідження користувачів показали, що використання такого способу, як звуження, цю інформацію надає ефективніше[6]. Висхідне планарне креслення[en] використовує домовленість, що кожне ребро орієнтується від нижчої до вищої вершини, що робить непотрібним зображення кінцівок стріл[7].
Альтернативні домовленості використовують такі уявлення суміжності, як пакування кіл[en], де вершини представлені у вигляді областей в площині, що не перетинаються, а ребра зображені як примикання між областями.
Зображення перетинів, в яких вершини зображені, як геометричні об'єкти, що не перетинаються, а ребра — їх перетинами.
Зображення видимості, в яких вершини представлені областями в площині, а ребра областями, що мають безперешкодну пряму видимість одне одного.
Зображення зливання, на яких ребра — гладкі, криві в межах математичних залізничних колій[en].
Зображення у вигляді тканини, де вершини представлені у вигляді горизонтальних ліній, а ребра у вигляді вертикальних ліній[8].
Багато різних критеріїв якості були визначені для креслень графа в спробі знайти об'єктивний спосіб оцінки їх естетичності та практичності[9]. Крім спрямування вибору між різними методами компонування для графа, деякі методи компонування намагаються безпосередньо оптимізувати ці заходи.
Числом схрещень креслення є число пар ребер, що перетинаються між собою. Якщо цей граф є планарним, то часто буває зручно зобразити його без будь-яких перетинів ребер; тобто, в такому випадку, графік являє собою граф вкладення. Однак неплоскі графи часто виникають у додатках, тому алгоритми малювання графа, як правило, повинні дозволяти перетин ребер[10].
Площина зображення — це найменша територія вікна обмеження графа, щодо найближчої відстані між будь-якими двома вершинами. Креслення з меншою площею, як правило, краще, ніж з більшою площею, бо вони дозволяють зберегти особливості малюнка, що будуть показані в більшому розмірі й, отже, більш розбірливо. Співвідношення сторін обмежувального блоку також може бути важливим.
Симетрія зображення — це проблема пошуку груп симетрії у даному графі, і знаходження зображення, що є найбільш симетричним. Деякі методи розташування автоматично ведуть до симетричних зображень; з іншого боку, деякі методи зображення починаються зі знаходження симетрії отриманого графа для його зображення[11].
Важливо, що ребра мають якомога простішу форму, аби оку людини було легше їх відстежувати. У полілінійних кресленнях, важкість конструкції ребра може вимірюватися у кількості згинів[en], і багато методів мають на меті надати креслення з невеликою кількістю загальних згинів або кількома згинами на ребро. Подібним чином для сплайн-кривих складність ребра може бути виміряна кількістю контрольних точок на ребрі.
Кілька популярних критеріїв якості, пов'язаних з довжиною ребер: в загальному випадку бажано звести до мінімуму загальну довжину країв, а також максимальну довжину будь-якого краю. Крім того, для довжин ребер може бути кращим залишатися однаковими, а не різноманітними.
Кутова роздільність — це міра найгострішого кута у зображенні графа. Якщо граф має вершини з великими степенями, то він обов'язково матиме не велику кутову роздільність, але кутова роздільність може бути обмежена знизу функцією степеня[12].
Число нахилів графа — це мінімальна кількість різних нахилів, що потрібні для зображення прямими лініями ребер сегмента (з перетином). Кубічний граф має кількість нахилів не більше чотирьох, але граф з п'ятьма кутами може мати необмежену кількість нахилів; ще залишається не зрозумілим, чи обмежена кількість нахилів 4-кутного графа[12].
Методи макетування
Існує багато стратегій компонування графів:
У системі силового компонування, програми зображення графів змінюють початкове розміщення вершин шляхом безперервного переміщення вершин відповідно до системи сил, заснованої на фізичних метафорах, пов'язаних з системами пружин або молекулярної механіки. Зазвичай, ці системи поєднують в собі сили тяжіння між сусідніми вершинами з силами відштовхування між усіма парами вершин, щоб знайти макет, в якому довжини ребер малі, в той час, як вершини добре розділені. Ці системи можуть виконувати метод найшвидшого спуску на основі мінімізації з функції енергії, або ж вони можуть перевести свої сили безпосередньо у швидкості або прискорення для рухомих вершин[14].
Ортогональні методи компонування, що дозволяють ребрам графа йти горизонтально або вертикально, паралельно осям координат макета. Ці методи були спочатку розроблені для схем надвеликого рівня інтеграції, друкованих плат і проблем компонування, але вони також були пристосовані до зображення графів. Вони зазвичай включають багатофазний підхід, в якому введення графа вирівнюється шляхом заміни точок перетину вершинами, знаходиться топологічне вкладення планаризованного графа, орієнтація сторін вибирається так, щоб звести до мінімуму вигини, вершини розташовуються послідовно з цими орієнтаціями, і, нарешті, етап ущільнення макету зменшує площу малюнка[16].
Алгоритми макету дерев використовують для зображення деревоподібних структур з коренем, зокрема, це пасує для дерев. Зазвичай, у техніці, що називається «кульовий макет» (англ.balloon layout), нащадок кожного вузла у дереві малюється на колі, що оточує вузол, із радіусом цих кіл, що спадає на нижчих рівнях дерева так, щоб ці кола не накладалися одне на одного[17].
Методи багаторівневого зображення графа[en] (які часто називають зображеннями у стилі Сугияма) найкраще підходять для орієнтованого ациклічного графа або графів, близьких до ациклічних, таких як графи залежностей між модулями або функціями в програмній системі. У цих методах, вузли графа розташовані на горизонтальних шарах з використанням методів, таких як алгоритм Коффмана-Грекхема[en], таким чином, що більшість ребер йдуть вниз від одного шару до іншого; після цього кроку вузли в кожному шарі розташовуються з метою мінімізації перетинів[18].
Дугова діаграма, це стиль компонування, відомий з 1960-х років[19], розташуємо вершини в одну лінію; ребра можуть бути зображені як півкола вище або нижче лінії, або як плавні криві, з'єднані з декількох півкіл.
У коловій схемі вершини обережно розташовані по колу, з метою зменшення перетинів та розташування сусідніх вершин якомога ближче одне до одного. Ребра можуть бути зображені як хорди кола чи його арки зсередини або зовні. Іноді можуть бути використані декілька кіл[20].
У макеті переважання[en] вершини записуються таким чином, що кожна вершина знаходиться вище, справа, або з обох боків від іншої, тоді й тільки тоді, коли вона досяжна[en] з цієї вершини. Таким чином, стиль макета робить відношення досяжності графа візуально очевидним[21].
Графічні креслення для конкретних додатків
Графи та зображення графа, що виникають в інших областях застосування, включають:
Крім того, розміщення[en] та трасування — кроки автоматизації проєктування електроніки (EDA) схожі у багатьох аспектах до зображення графів, оскільки існує проблема жадібних вкладень[en] у розподілених обчисленнях, та література з зображення графів містить декілька результатів, позичених з літератури EDA. Однак, ці проблеми також різняться у деяких важливих аспектах: наприклад, у EDA, область мінімізації та довжина сигналу важливіші за естетичність, але проблеми зв'язку у EDA можуть мати понад два термінали на мережу у той час, як аналогічна проблема у зображенні графа зазвичай містить пари вершин для кожного ребра.
Програмне забезпечення
Програмне забезпечення, системи та провайдери систем для малювання графів:
↑Knuth, Donald E. (2013), Two thousand years of combinatorics, у Wilson, Robin; Watkins, John J. (ред.), Combinatorics: Ancient and Modern, Oxford University Press, с. 7—37.
↑«Graphviz and Dynagraph — Static and Dynamic Graph Drawing Tools», by John Ellson, Emden R. Gansner, Eleftherios Koutsofios, Stephen C. North, and Gordon Woodhull, in Jünger та Mutzel, (2004).
Bachmaier, Christian; Brandes, Ulrik; Schreiber, Falk (2014), Biological Networks, у Tamassia, Roberto (ред.), Handbook of Graph Drawing and Visualization, CRC Press, с. 621—651.
Bastert, Oliver; Matuszewski, Christian (2001), Layered drawings of digraphs, у Kaufmann, Michael; Wagner, Dorothea (ред.), Drawing Graphs: Methods and Models, Lecture Notes in Computer Science, т. 2025, Springer-Verlag, с. 87—120, doi:10.1007/3-540-44969-8_5.
Beckman, Brian (1994), Theory of Spectral Graph Layout, Tech. Report MSR-TR-94-04, Microsoft Research, архів оригіналу за 1 квітня 2016, процитовано 20 березня 2016.
Brandes, Ulrik; Freeman, Linton C.; Wagner, Dorothea (2014), Social Networks, у Tamassia, Roberto (ред.), Handbook of Graph Drawing and Visualization, CRC Press, с. 805—839.
Di Battista, Giuseppe; Rimondini, Massimo (2014), Computer Networks, у Tamassia, Roberto (ред.), Handbook of Graph Drawing and Visualization, CRC Press, с. 763—803.
Madden, Brendan; Madden, Patrick; Powers, Steve; Himsolt, Michael (1996), Portable graph layout and editing, у Brandenburg, Franz J. (ред.), Graph Drawing: Symposium on Graph Drawing, GD '95, Passau, Germany, September 20–22, 1995, Proceedings, Lecture Notes in Computer Science, т. 1027, Springer-Verlag, с. 385—395, doi:10.1007/BFb0021822.
Misue, K.; Eades, P.; Lai, W.; Sugiyama, K. (1995), Layout Adjustment and the Mental Map, Journal of Visual Languages and Computing, 6 (2): 183—210, doi:10.1006/jvlc.1995.1010.
Pach, János; Sharir, Micha (2009), 5.5 Angular resolution and slopes, Combinatorial Geometry and Its Algorithmic Applications: The Alcalá Lectures, Mathematical Surveys and Monographs, т. 152, American Mathematical Society, с. 126—127.
GraphX library for .NET [Архівовано 26 січня 2018 у Wayback Machine.]: WPF бібліотека з відкритим кодом для обчислення та візуалізації графів. Підтримує багато макетів та алгоритмів з'єднання сторін.