Graphviz 13.0.0~dev.20250121.0651
Loading...
Searching...
No Matches
general.c
Go to the documentation of this file.
1/*************************************************************************
2 * Copyright (c) 2011 AT&T Intellectual Property
3 * All rights reserved. This program and the accompanying materials
4 * are made available under the terms of the Eclipse Public License v1.0
5 * which accompanies this distribution, and is available at
6 * https://www.eclipse.org/legal/epl-v10.html
7 *
8 * Contributors: Details at https://graphviz.org
9 *************************************************************************/
10
11#include <math.h>
12#include <stdbool.h>
13#include <stddef.h>
14#include <sparse/general.h>
15#include <errno.h>
16#include <util/alloc.h>
17
18#ifdef DEBUG
19double _statistics[10];
20#endif
21
22double drand(void){
23 return rand()/(double) RAND_MAX;
24}
25
26int irand(int n){
27 /* 0, 1, ..., n-1 */
28 assert(n > 1);
29 /*return (int) MIN(floor(drand()*n),n-1);*/
30 return rand()%n;
31}
32
34 int i, j, pp, len;
35 if (n <= 0) return NULL;
36 int *p = gv_calloc(n, sizeof(int));
37 for (i = 0; i < n; i++) p[i] = i;
38
39 len = n;
40 while (len > 1){
41 j = irand(len);
42 pp = p[len-1];
43 p[len-1] = p[j];
44 p[j] = pp;
45 len--;
46 }
47 return p;
48}
49
50
51double* vector_subtract_to(int n, double *x, double *y){
52 /* y = x-y */
53 int i;
54 for (i = 0; i < n; i++) y[i] = x[i] - y[i];
55 return y;
56}
57double vector_product(int n, double *x, double *y){
58 double res = 0;
59 int i;
60 for (i = 0; i < n; i++) res += x[i]*y[i];
61 return res;
62}
63
64double* vector_saxpy(int n, double *x, double *y, double beta){
65 /* y = x+beta*y */
66 int i;
67 for (i = 0; i < n; i++) y[i] = x[i] + beta*y[i];
68 return y;
69}
70
71double* vector_saxpy2(int n, double *x, double *y, double beta){
72 /* x = x+beta*y */
73 int i;
74 for (i = 0; i < n; i++) x[i] = x[i] + beta*y[i];
75 return x;
76}
77
78void vector_float_take(int n, float *v, int m, int *p, float **u){
79 /* take m elements v[p[i]]],i=1,...,m and oput in u */
80 int i;
81
82 if (!*u) *u = gv_calloc(m, sizeof(float));
83
84 for (i = 0; i < m; i++) {
85 assert(p[i] < n && p[i] >= 0);
86 (void)n;
87 (*u)[i] = v[p[i]];
88 }
89
90}
91
92static int comp_ascend(const void *s1, const void *s2){
93 const double *ss1 = s1;
94 const double *ss2 = s2;
95
96 if (ss1[0] > ss2[0]){
97 return 1;
98 } else if (ss1[0] < ss2[0]){
99 return -1;
100 }
101 return 0;
102}
103
104static int comp_ascend_int(const void *s1, const void *s2){
105 const int *ss1 = s1;
106 const int *ss2 = s2;
107
108 if (ss1[0] > ss2[0]){
109 return 1;
110 } else if (ss1[0] < ss2[0]){
111 return -1;
112 }
113 return 0;
114}
115
116void vector_ordering(int n, double *v, int **p){
117 /* give the position of the smallest, second smallest etc in vector v.
118 results in p. If *p == NULL, p is assigned.
119 */
120
121 int i;
122
123 if (!*p) *p = gv_calloc(n, sizeof(int));
124 double *u = gv_calloc(2 * n, sizeof(double));
125
126 for (i = 0; i < n; i++) {
127 u[2*i+1] = i;
128 u[2*i] = v[i];
129 }
130
131 qsort(u, n, sizeof(double)*2, comp_ascend);
132
133 for (i = 0; i < n; i++) (*p)[i] = (int) u[2*i+1];
134 free(u);
135}
136
137void vector_sort_int(int n, int *v){
138 qsort(v, n, sizeof(int), comp_ascend_int);
139}
140
141double distance_cropped(double *x, int dim, int i, int j){
142 double dist = distance(x, dim, i, j);
143 return fmax(dist, MINDIST);
144}
145
146double distance(double *x, int dim, int i, int j){
147 int k;
148 double dist = 0.;
149 for (k = 0; k < dim; k++) dist += (x[i*dim+k] - x[j*dim + k])*(x[i*dim+k] - x[j*dim + k]);
150 dist = sqrt(dist);
151 return dist;
152}
153
154double point_distance(double *p1, double *p2, int dim){
155 int i;
156 double dist;
157 dist = 0;
158 for (i = 0; i < dim; i++) dist += (p1[i] - p2[i])*(p1[i] - p2[i]);
159 return sqrt(dist);
160}
161
162char *strip_dir(char *s){
163 bool first = true;
164 if (!s) return s;
165 for (size_t i = strlen(s); ; i--) {
166 if (first && s[i] == '.') {/* get rid of .mtx */
167 s[i] = '\0';
168 first = false;
169 }
170 if (s[i] == '/') return &s[i+1];
171 if (i == 0) {
172 break;
173 }
174 }
175 return s;
176}
Memory allocation wrappers that exit on failure.
static void * gv_calloc(size_t nmemb, size_t size)
Definition alloc.h:26
#define MINDIST
Definition circular.c:16
static double dist(int dim, double *x, double *y)
int * random_permutation(int n)
Definition general.c:33
double * vector_saxpy(int n, double *x, double *y, double beta)
Definition general.c:64
double drand(void)
Definition general.c:22
double * vector_saxpy2(int n, double *x, double *y, double beta)
Definition general.c:71
char * strip_dir(char *s)
Definition general.c:162
void vector_ordering(int n, double *v, int **p)
Definition general.c:116
double distance(double *x, int dim, int i, int j)
Definition general.c:146
double vector_product(int n, double *x, double *y)
Definition general.c:57
static int comp_ascend_int(const void *s1, const void *s2)
Definition general.c:104
void vector_float_take(int n, float *v, int m, int *p, float **u)
Definition general.c:78
void vector_sort_int(int n, int *v)
Definition general.c:137
int irand(int n)
Definition general.c:26
double * vector_subtract_to(int n, double *x, double *y)
Definition general.c:51
double distance_cropped(double *x, int dim, int i, int j)
Definition general.c:141
double point_distance(double *p1, double *p2, int dim)
Definition general.c:154
static int comp_ascend(const void *s1, const void *s2)
Definition general.c:92
static double len(glCompPoint p)
Definition glutils.c:150
void free(void *)
node NULL
Definition grammar.y:163
static const int dim
NEATOPROCS_API void s1(graph_t *, node_t *)
Definition stuff.c:671
Definition grammar.c:93