Graphviz 13.0.0~dev.20250121.0651
|
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include <time.h>
#include <assert.h>
#include <common/arith.h>
#include <topfish/hierarchy.h>
#include <util/alloc.h>
Go to the source code of this file.
Macros | |
#define | A 1.0 |
#define | B 1.0 |
#define | C 3.0 |
#define | D 1.0 |
Functions | |
static double | unweighted_common_fraction (v_data *graph, int v, int u, float *v_vector) |
static void | fill_neighbors_vec (v_data *graph, int vtx, float *vtx_vec) |
static void | fill_neighbors_vec_unweighted (v_data *graph, int vtx, float *vtx_vec) |
static void | empty_neighbors_vec (v_data *graph, int vtx, float *vtx_vec) |
static int | dist3 (v_data *graph, int node1, int node2) |
static double | ddist (ex_vtx_data *geom_graph, int v, int u) |
void | quicksort_place (double *, int *, size_t size) |
static int | maxmatch (v_data *graph, ex_vtx_data *geom_graph, int nvtxs, int *mflag, int dist2_limit) |
static void | makev2cv (int *mflag, int nvtxs, int *v2cv, int *cv2v) |
static int | make_coarse_graph (v_data *graph, int nedges, v_data **cgp, int cnvtxs, int *v2cv, int *cv2v) |
static int | make_coarse_ex_graph (ex_vtx_data *graph, int nedges, ex_vtx_data **cgp, int cnvtxs, int *v2cv, int *cv2v) |
static void | coarsen_match (v_data *graph, ex_vtx_data *geom_graph, int nvtxs, int nedges, int geom_nedges, v_data **cgraph, ex_vtx_data **cgeom_graph, int *cnp, int *cnedges, int *cgeom_nedges, int **v2cvp, int **cv2vp, int dist2_limit) |
static v_data * | cpGraph (v_data *graph, int n, int nedges) |
static ex_vtx_data * | cpExGraph (ex_vtx_data *graph, int n, int nedges) |
Hierarchy * | create_hierarchy (v_data *graph, int nvtxs, int nedges, ex_vtx_data *geom_graph, int ngeom_edges, hierparms_t *parms) |
static double | dist_from_foci (ex_vtx_data *graph, int node, int *foci, int num_foci) |
void | set_active_levels (Hierarchy *hierarchy, int *foci_nodes, int num_foci, levelparms_t *parms) |
static double | findClosestActiveNode (Hierarchy *hierarchy, int node, int level, double x, double y, double closest_dist, int *closest_node, int *closest_node_level) |
static int | find_leftmost_descendant (Hierarchy *hierarchy, int node, int level, int cur_level) |
double | find_closest_active_node (Hierarchy *hierarchy, double x, double y, int *closest_fine_node) |
int | init_ex_graph (v_data *graph1, v_data *graph2, int n, double *x_coords, double *y_coords, ex_vtx_data **gp) |
size_t | extract_active_logical_coords (Hierarchy *hierarchy, int node, int level, double *x_coords, double *y_coords, size_t counter) |
int | set_active_physical_coords (Hierarchy *hierarchy, int node, int level, double *x_coords, double *y_coords, int counter) |
void | find_physical_coords (Hierarchy *hierarchy, int level, int node, double *x, double *y) |
void | find_active_ancestor_info (Hierarchy *hierarchy, int level, int node, int *levell, int *nodee) |
void | find_old_physical_coords (Hierarchy *hierarchy, int level, int node, double *x, double *y) |
int | find_active_ancestor (Hierarchy *hierarchy, int level, int node) |
void | init_active_level (Hierarchy *hierarchy, int level) |
#define A 1.0 |
Definition at line 116 of file hierarchy.c.
#define B 1.0 |
Definition at line 117 of file hierarchy.c.
#define C 3.0 |
Definition at line 118 of file hierarchy.c.
#define D 1.0 |
Definition at line 119 of file hierarchy.c.
|
static |
Definition at line 561 of file hierarchy.c.
References free(), graph(), gv_calloc(), make_coarse_ex_graph(), make_coarse_graph(), makev2cv(), maxmatch(), and nedges.
Referenced by create_hierarchy().
|
static |
Definition at line 644 of file hierarchy.c.
References cpGraph(), v_data::edges, graph(), gv_calloc(), nedges, and NULL.
Referenced by create_hierarchy().
Definition at line 612 of file hierarchy.c.
References cpGraph(), v_data::edges, v_data::ewgts, graph(), gv_calloc(), nedges, and NULL.
Referenced by cpExGraph(), cpGraph(), and create_hierarchy().
Hierarchy * create_hierarchy | ( | v_data * | graph, |
int | nvtxs, | ||
int | nedges, | ||
ex_vtx_data * | geom_graph, | ||
int | ngeom_edges, | ||
hierparms_t * | parms | ||
) |
Definition at line 665 of file hierarchy.c.
References coarsen_match(), cpExGraph(), cpGraph(), Hierarchy::cv2v, Hierarchy::geom_graphs, ex_vtx_data::globalIndex, graph(), Hierarchy::graphs, gv_alloc(), gv_calloc(), gv_recalloc(), MAX, Hierarchy::maxNodeIndex, nedges, Hierarchy::nedges, Hierarchy::nlevels, Hierarchy::nvtxs, parms, and Hierarchy::v2cv.
Referenced by makeHier().
|
static |
Definition at line 121 of file hierarchy.c.
References ex_vtx_data::x_coord, and ex_vtx_data::y_coord.
Referenced by dist_from_foci(), and maxmatch().
|
static |
Definition at line 91 of file hierarchy.c.
References graph().
Referenced by maxmatch().
|
static |
Definition at line 733 of file hierarchy.c.
References ddist(), distance(), graph(), and MIN.
Referenced by set_active_levels().
|
static |
Definition at line 82 of file hierarchy.c.
References graph().
Referenced by maxmatch().
size_t extract_active_logical_coords | ( | Hierarchy * | hierarchy, |
int | node, | ||
int | level, | ||
double * | x_coords, | ||
double * | y_coords, | ||
size_t | counter | ||
) |
Definition at line 999 of file hierarchy.c.
References Hierarchy::cv2v, extract_active_logical_coords(), Hierarchy::geom_graphs, and graph().
Referenced by extract_active_logical_coords(), and positionAllItems().
|
static |
Definition at line 59 of file hierarchy.c.
Referenced by maxmatch().
|
static |
Definition at line 73 of file hierarchy.c.
References graph().
Referenced by maxmatch().
int find_active_ancestor | ( | Hierarchy * | hierarchy, |
int | level, | ||
int | node | ||
) |
Definition at line 1115 of file hierarchy.c.
References ex_vtx_data::active_level, Hierarchy::geom_graphs, ex_vtx_data::globalIndex, and Hierarchy::v2cv.
void find_active_ancestor_info | ( | Hierarchy * | hierarchy, |
int | level, | ||
int | node, | ||
int * | levell, | ||
int * | nodee | ||
) |
Definition at line 1078 of file hierarchy.c.
References ex_vtx_data::active_level, Hierarchy::geom_graphs, and Hierarchy::v2cv.
Referenced by drawtopfishedges().
double find_closest_active_node | ( | Hierarchy * | hierarchy, |
double | x, | ||
double | y, | ||
int * | closest_fine_node | ||
) |
Definition at line 929 of file hierarchy.c.
References find_leftmost_descendant(), findClosestActiveNode(), Hierarchy::nlevels, and Hierarchy::nvtxs.
Referenced by changetopfishfocus().
|
static |
Definition at line 913 of file hierarchy.c.
References Hierarchy::cv2v.
Referenced by find_closest_active_node().
void find_old_physical_coords | ( | Hierarchy * | hierarchy, |
int | level, | ||
int | node, | ||
double * | x, | ||
double * | y | ||
) |
Definition at line 1097 of file hierarchy.c.
References Hierarchy::geom_graphs, ex_vtx_data::old_active_level, ex_vtx_data::old_physical_x_coord, ex_vtx_data::old_physical_y_coord, and Hierarchy::v2cv.
Referenced by get_temp_coords().
void find_physical_coords | ( | Hierarchy * | hierarchy, |
int | level, | ||
int | node, | ||
double * | x, | ||
double * | y | ||
) |
Definition at line 1064 of file hierarchy.c.
References ex_vtx_data::active_level, Hierarchy::geom_graphs, ex_vtx_data::physical_x_coord, ex_vtx_data::physical_y_coord, and Hierarchy::v2cv.
Referenced by get_temp_coords().
|
static |
Definition at line 867 of file hierarchy.c.
References Hierarchy::cv2v, dist(), findClosestActiveNode(), Hierarchy::geom_graphs, and graph().
Referenced by find_closest_active_node(), and findClosestActiveNode().
void init_active_level | ( | Hierarchy * | hierarchy, |
int | level | ||
) |
Definition at line 1129 of file hierarchy.c.
References Hierarchy::geom_graphs, graph(), Hierarchy::nlevels, and Hierarchy::nvtxs.
Referenced by makeHier().
int init_ex_graph | ( | v_data * | graph1, |
v_data * | graph2, | ||
int | n, | ||
double * | x_coords, | ||
double * | y_coords, | ||
ex_vtx_data ** | gp | ||
) |
Definition at line 946 of file hierarchy.c.
References v_data::edges, ex_vtx_data::edges, gv_calloc(), nedges, v_data::nedges, ex_vtx_data::nedges, neighbor, ex_vtx_data::size, ex_vtx_data::x_coord, and ex_vtx_data::y_coord.
Referenced by makeHier().
|
static |
Definition at line 482 of file hierarchy.c.
References ex_vtx_data::edges, free(), graph(), gv_calloc(), nedges, ex_vtx_data::nedges, neighbor, ex_vtx_data::size, ex_vtx_data::x_coord, and ex_vtx_data::y_coord.
Referenced by coarsen_match().
|
static |
Definition at line 337 of file hierarchy.c.
References v_data::edges, v_data::ewgts, free(), graph(), gv_calloc(), nedges, v_data::nedges, neighbor, and NULL.
Referenced by coarsen_match().
|
static |
Definition at line 312 of file hierarchy.c.
Referenced by coarsen_match().
|
static |
Definition at line 133 of file hierarchy.c.
References A, B, C, ddist(), dist3(), ex_vtx_data::edges, empty_neighbors_vec(), fill_neighbors_vec(), fill_neighbors_vec_unweighted(), free(), graph(), gv_calloc(), MIN, nedges, ex_vtx_data::nedges, neighbor, NULL, quicksort_place(), ex_vtx_data::size, and unweighted_common_fraction().
Referenced by coarsen_match().
|
extern |
Definition at line 105 of file rescale_layout.c.
References cmp(), and gv_sort().
Referenced by maxmatch(), and set_active_levels().
void set_active_levels | ( | Hierarchy * | hierarchy, |
int * | foci_nodes, | ||
int | num_foci, | ||
levelparms_t * | parms | ||
) |
Definition at line 753 of file hierarchy.c.
References ex_vtx_data::active_level, Hierarchy::cv2v, dist_from_foci(), free(), Hierarchy::geom_graphs, graph(), gv_calloc(), MIN, Hierarchy::nlevels, Hierarchy::nvtxs, parms, and quicksort_place().
Referenced by changetopfishfocus(), and prepare_topological_fisheye().
int set_active_physical_coords | ( | Hierarchy * | hierarchy, |
int | node, | ||
int | level, | ||
double * | x_coords, | ||
double * | y_coords, | ||
int | counter | ||
) |
Definition at line 1033 of file hierarchy.c.
References Hierarchy::cv2v, Hierarchy::geom_graphs, graph(), and set_active_physical_coords().
Referenced by positionAllItems(), and set_active_physical_coords().
|
static |
Definition at line 35 of file hierarchy.c.
References graph(), and neighbor.
Referenced by maxmatch().