Graph::createRandomEdgeWeights

Устанавливает случайные веса на ребра

Блокноты MuPAD® будут демонтированы в будущем релизе. Используйте live скрипты MATLAB® вместо этого.

Live скрипты MATLAB поддерживают большую часть функциональности MuPAD, хотя существуют некоторые различия. Для получения дополнительной информации смотрите, Преобразуют Notebook MuPAD в Live скрипты MATLAB.

Синтаксис

Graph::createRandomEdgeWeights(G, r, <Dom::Integer | Dom::Real>)

Описание

Graph::createRandomEdgeWeights(G, x..y) создает случайный целочисленный вес ребра в области значений x..y.

Graph::createRandomEdgeWeights(G, x..y, Dom::Integer) делает точно то же самое.

Graph::createRandomEdgeWeights(G, x..y, Dom::Real) создает случайный действительный вес ребра в области значений x..y.

Примечание

Уже существующий вес ребра будет изменен, также!

Примеры

Пример 1

Создание веса ребра для маленького циклического графика. Во-первых, это не имеет никаких заданных весов:

G1 := Graph::createCircleGraph(5):
Graph::printGraphInformation(G1)
Vertices: [1, 2, 3, 4, 5]
Edges: [[1, 2], [2, 3], [3, 4], [4, 5], [5, 1]]
Vertex weights: no vertex weights.
Edge descriptions: no edge descriptions.
Edge weights: no edge weights.
Edge costs: no edge costs.
Adjacency list (out): 1 = [2], 2 = [3], 3 = [4], 4 = [5], 5 = [1]
Adjacency list (in): 1 = [5], 2 = [1], 3 = [2], 4 = [3], 5 = [4]
Graph is directed.

Теперь веса установлены в области значений -100..50 (ваш выход может отличаться должное случайное присвоение):

G2 := Graph::createRandomEdgeWeights(G1, -100..50):
Graph::printGraphInformation(G2)
Vertices: [1, 2, 3, 4, 5]
Edges: [[1, 2], [2, 3], [3, 4], [4, 5], [5, 1]]
Vertex weights: no vertex weights.
Edge descriptions: no edge descriptions.
Edge weights: [1, 2] = 47, [2, 3] = -12, [3, 4] = 28, [4, 5] = 1, [5, 1] =\
 -36 (other existing edges have no weight)
Edge costs: no edge costs.
Adjacency list (out): 1 = [2], 2 = [3], 3 = [4], 4 = [5], 5 = [1]
Adjacency list (in): 1 = [5], 2 = [1], 3 = [2], 4 = [3], 5 = [4]
Graph is directed.

Если веса должны иметь тип, Действительный, он может быть установлен опционально:

G2 := Graph::createRandomEdgeWeights(G1, -100..50, Dom::Real):
Graph::printGraphInformation(G2)
Vertices: [1, 2, 3, 4, 5]
Edges: [[1, 2], [2, 3], [3, 4], [4, 5], [5, 1]]
Vertex weights: no vertex weights.
Edge descriptions: no edge descriptions.
Edge weights: [1, 2] = -67.72964183, [2, 3] = -10.16896282, [3, 4] = -72.8\
4684348, [4, 5] = -61.00518722, [5, 1] = 18.2662729 (other existing edges \
have no weight)
Edge costs: no edge costs.
Adjacency list (out): 1 = [2], 2 = [3], 3 = [4], 4 = [5], 5 = [1]
Adjacency list (in): 1 = [5], 2 = [1], 3 = [2], 4 = [3], 5 = [4]
Graph is directed.

Параметры

G

График

r

Область значений

Возвращаемые значения

График