Line | |
---|
1 | /*!\file SplitSolutionVectorx
|
---|
2 | */
|
---|
3 |
|
---|
4 | #include "./SplitSolutionVectorx.h"
|
---|
5 | #include "../shared/shared.h"
|
---|
6 |
|
---|
7 | void SplitSolutionVectorx(Vec u_g,int numberofnodes,int numberofdofs, ...){
|
---|
8 |
|
---|
9 | /*http://www.dreamincode.net/forums/topic/79104-variadic-functions-or-how-printf-works */
|
---|
10 |
|
---|
11 | /*Intermediary*/
|
---|
12 | va_list outputlist;
|
---|
13 | double* u_g_serial=NULL;
|
---|
14 | double** pvector;
|
---|
15 | int i,count;
|
---|
16 |
|
---|
17 | /*Serialize vector and allocate once for all*/
|
---|
18 | VecToMPISerial(&u_g_serial,u_g);
|
---|
19 |
|
---|
20 | /* va_start() takes the arg list type we just declared, as well
|
---|
21 | as the last argument in this function's definition, ie. 'int numberofdofs'*/
|
---|
22 | va_start(outputlist,numberofdofs);
|
---|
23 |
|
---|
24 | /*Loop over the arguments*/
|
---|
25 | count=0;
|
---|
26 | while (count<numberofdofs){
|
---|
27 | /* va_arg() takes the arg list from above, and the type
|
---|
28 | the argument is supposed to be and then (hopefully) returns it*/
|
---|
29 | pvector=va_arg(outputlist,double**);
|
---|
30 |
|
---|
31 | //continue if the pointer is NULL (output not requested)
|
---|
32 | if (pvector==NULL) continue;
|
---|
33 |
|
---|
34 | /*Dynamically allocate single dof vector*/
|
---|
35 | double* vector=NULL;
|
---|
36 | vector=(double*)xmalloc(numberofnodes*sizeof(double));
|
---|
37 |
|
---|
38 | /*Fill vector*/
|
---|
39 | for (i=0;i<numberofnodes;i++) vector[i]=u_g_serial[i*numberofdofs+count];
|
---|
40 |
|
---|
41 | /*Assign vector*/
|
---|
42 | *pvector=vector;
|
---|
43 |
|
---|
44 | /*update counter*/
|
---|
45 | count++;
|
---|
46 | }
|
---|
47 | va_end (outputlist);
|
---|
48 | }
|
---|
Note:
See
TracBrowser
for help on using the repository browser.