Skip to content
GitLab
Menu
Projects
Groups
Snippets
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
Iker Martín Álvarez
Proteo
Commits
178383ba
Commit
178383ba
authored
Jul 12, 2021
by
iker_martin
Browse files
Pequeñas anotaciones. Se ha encontrado un error de memoria relacionado con Alltoallv
parent
5e73e8ba
Changes
2
Show whitespace changes
Inline
Side-by-side
Codes/IOcodes/results.c
View file @
178383ba
...
@@ -162,7 +162,7 @@ void init_results_data(results_data **results, int resizes, int iters_size) {
...
@@ -162,7 +162,7 @@ void init_results_data(results_data **results, int resizes, int iters_size) {
(
*
results
)
->
async_time
=
calloc
(
resizes
,
sizeof
(
double
));
(
*
results
)
->
async_time
=
calloc
(
resizes
,
sizeof
(
double
));
(
*
results
)
->
iters_size
=
iters_size
+
100
;
(
*
results
)
->
iters_size
=
iters_size
+
100
;
(
*
results
)
->
iters_time
=
calloc
(
iters_size
+
100
,
sizeof
(
double
));
//FIXME Numero magico
- Añadir funcion que amplie tamaño
(
*
results
)
->
iters_time
=
calloc
(
iters_size
+
100
,
sizeof
(
double
));
//FIXME Numero magico
(
*
results
)
->
iters_type
=
calloc
(
iters_size
+
100
,
sizeof
(
int
));
(
*
results
)
->
iters_type
=
calloc
(
iters_size
+
100
,
sizeof
(
int
));
(
*
results
)
->
iter_index
=
0
;
(
*
results
)
->
iter_index
=
0
;
}
}
...
...
Codes/malleability/CommDist.c
View file @
178383ba
...
@@ -139,7 +139,6 @@ void recv_sync(char **array, int qty, int myId, int numP, int root, MPI_Comm int
...
@@ -139,7 +139,6 @@ void recv_sync(char **array, int qty, int myId, int numP, int root, MPI_Comm int
void
send_sync_arrays
(
struct
Dist_data
dist_data
,
char
*
array
,
int
rootBcast
,
int
numP_child
,
int
idI
,
int
idE
,
struct
Counts
counts
)
{
void
send_sync_arrays
(
struct
Dist_data
dist_data
,
char
*
array
,
int
rootBcast
,
int
numP_child
,
int
idI
,
int
idE
,
struct
Counts
counts
)
{
int
i
;
int
i
;
// PREPARAR ENVIO DEL VECTOR
// PREPARAR ENVIO DEL VECTOR
if
(
idI
==
0
)
{
if
(
idI
==
0
)
{
set_counts
(
0
,
numP_child
,
dist_data
,
counts
.
counts
);
set_counts
(
0
,
numP_child
,
dist_data
,
counts
.
counts
);
...
@@ -150,7 +149,6 @@ void send_sync_arrays(struct Dist_data dist_data, char *array, int rootBcast, in
...
@@ -150,7 +149,6 @@ void send_sync_arrays(struct Dist_data dist_data, char *array, int rootBcast, in
counts
.
displs
[
i
]
=
counts
.
displs
[
i
-
1
]
+
counts
.
counts
[
i
-
1
];
counts
.
displs
[
i
]
=
counts
.
displs
[
i
-
1
]
+
counts
.
counts
[
i
-
1
];
}
}
//print_counts(dist_data, counts.counts, counts.displs, numP_child, "Padres");
//print_counts(dist_data, counts.counts, counts.displs, numP_child, "Padres");
/* COMUNICACION DE DATOS */
/* COMUNICACION DE DATOS */
MPI_Alltoallv
(
array
,
counts
.
counts
,
counts
.
displs
,
MPI_CHAR
,
NULL
,
counts
.
zero_arr
,
counts
.
zero_arr
,
MPI_CHAR
,
dist_data
.
intercomm
);
MPI_Alltoallv
(
array
,
counts
.
counts
,
counts
.
displs
,
MPI_CHAR
,
NULL
,
counts
.
zero_arr
,
counts
.
zero_arr
,
MPI_CHAR
,
dist_data
.
intercomm
);
...
@@ -164,7 +162,7 @@ void send_sync_arrays(struct Dist_data dist_data, char *array, int rootBcast, in
...
@@ -164,7 +162,7 @@ void send_sync_arrays(struct Dist_data dist_data, char *array, int rootBcast, in
void
recv_sync_arrays
(
struct
Dist_data
dist_data
,
char
*
array
,
int
root
,
int
numP_parents
,
int
idI
,
int
idE
,
struct
Counts
counts
)
{
void
recv_sync_arrays
(
struct
Dist_data
dist_data
,
char
*
array
,
int
root
,
int
numP_parents
,
int
idI
,
int
idE
,
struct
Counts
counts
)
{
int
i
;
int
i
;
char
*
aux
=
malloc
(
1
)
;
char
aux
;
// Ajustar los valores de recepcion
// Ajustar los valores de recepcion
if
(
idI
==
0
)
{
if
(
idI
==
0
)
{
...
@@ -178,8 +176,7 @@ void recv_sync_arrays(struct Dist_data dist_data, char *array, int root, int num
...
@@ -178,8 +176,7 @@ void recv_sync_arrays(struct Dist_data dist_data, char *array, int root, int num
//print_counts(dist_data, counts.counts, counts.displs, numP_parents, "Hijos");
//print_counts(dist_data, counts.counts, counts.displs, numP_parents, "Hijos");
/* COMUNICACION DE DATOS */
/* COMUNICACION DE DATOS */
MPI_Alltoallv
(
aux
,
counts
.
zero_arr
,
counts
.
zero_arr
,
MPI_CHAR
,
array
,
counts
.
counts
,
counts
.
displs
,
MPI_CHAR
,
dist_data
.
intercomm
);
MPI_Alltoallv
(
&
aux
,
counts
.
zero_arr
,
counts
.
zero_arr
,
MPI_CHAR
,
array
,
counts
.
counts
,
counts
.
displs
,
MPI_CHAR
,
dist_data
.
intercomm
);
free
(
aux
);
}
}
...
...
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment