Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
 Аватар для Anett
0 / 0 / 0
Регистрация: 08.01.2013
Сообщений: 8

Создание кластеров в графе. Сворачивание вершин

01.02.2016, 00:34. Показов 1520. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть библиотека vis.js , позволяющая отрисовать графы разных видов и производить какие-либо манипуляции с ними. В том числе можно свернуть несколько вершин в кластер (то есть спрятать несколько маленьких вершин в одну большую, например). Я поняла, как разворачиваются эти вершины, но вот алгоритм сворачивания не могу уловить. В функцию передаем scale - то есть значение "зума". Логика такая: маленький масштаб - все вершины прячем в кластеры, большой - полностью разворачиваем граф. Что примечательно, кластер может прятаться в кластер.

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
    function makeClusters(scale) {
        var clusterOptionsByData = {
            processProperties: function (clusterOptions, childNodes) {
                clusterIndex = clusterIndex + 1;
                var childrenCount = 0;
                for (var i = 0; i < childNodes.length; i++) {
                    childrenCount += childNodes[i].childrenCount || 1;
                }
                clusterOptions.childrenCount = childrenCount;
                clusterOptions.label = "# " + childrenCount + "";
                clusterOptions.font = {size: childrenCount*5+30}
                clusterOptions.id = 'cluster:' + clusterIndex;
                clusters.push({id:'cluster:' + clusterIndex, scale:scale});
                return clusterOptions;
            },
            clusterNodeProperties: {borderWidth: 3, shape: 'database', font: {size: 30}}
        }
Вообще не понятна вот эта строчка:
JavaScript
1
processProperties: function (clusterOptions, childNodes)
Чем может быть processProperties ?

И не очень понятна логика действий вот тут:
JavaScript
1
2
3
for (var i = 0; i < childNodes.length; i++) {
                    childrenCount += childNodes[i].childrenCount || 1;
                }
Источник:
https://github.com/almende/vis... work/other
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.02.2016, 00:34
Ответы с готовыми решениями:

Вывести центроиды кластеров графе, представленным матрицей
Всем привет. Имеем граф, представленный матрицей nxm (n==m), где A=кратчайший путь из n1 в m1 и т.д. Матрица является результатом...

Как найти число вершин и ребер в графе окресности каждой пары вершин
Как найти число вершин и ребер в графе окресности каждой пары вершин? Добавлено через 5 минут В принципе, я написал, но мне сказал...

Номера вершин в графе
Здравствуйте! Я уже задавал здесь подобный вопрос, однако никто ответить однозначно не смог, хотя задача как мне кажется тривиальная. ...

1
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
01.02.2016, 22:34
Anett, не знаю что такое processProperties, но думаю, что это типа "обработчика свойств"
то есть он смотрит на все свойства, потом думает что с ними делать, потом отдаёт какие-то другие свойства или результат размышлений
а строчка
JavaScript
1
childrenCount += childNodes[i].childrenCount || 1;
просто суммирует всех чилдов(вершин)
то есть она перебирает всех чилдов переданного ей графика или я не знаю чего там передаётся
и потом просто суммируются число чилдов этих чилдов(тофтология 1000lvl) и если у вершины нету чилдов, то просто приплюсовывает эту вершину
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.02.2016, 22:34
Помогаю со студенческими работами здесь

Нумерация вершин в графе
Здравствуйте! Как известно, нумерация вершин в графе принята от 0 до n. Например: 0 1 1 2 Это удобно, так как...

Сколько в этом графе вершин и рёбер?
В плоском двусвязном графе 7 граней (считая внешнюю) - 3 треугольника, 3 четырехугольника и пятиугольник. Сколько в этом графе вершин и...

Смежность и инцидентность ребер и вершин в графе.
Нужно взять любой граф (желательно попроще), ввести его програму. потом вводим 2 вершины, программа говорит, смежны ли они. затем вводим...

Алгоритм нахождения вершин маршрута в графе
По запросам в поисковике всё время выдаёт решение на тему поиск кратчайшего пути, мне это не нужно, мне это будет много. А нужен всего...

Определить множество вершин, максимально удаленных от корня, на графе
Для ориентированного графа G с вершинами v(i) є v(|V| &lt;= 80) и ребрами е(k) є E (|E| &lt;= 150) определить множество вершин, максимально...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru