/[escript]/trunk/finley/src/NodeFile_copyTable.c
ViewVC logotype

Diff of /trunk/finley/src/NodeFile_copyTable.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

trunk/esys2/finley/src/finleyC/NodeFile_copyTable.c revision 82 by jgs, Tue Oct 26 06:53:54 2004 UTC trunk/finley/src/NodeFile_copyTable.c revision 1811 by ksteube, Thu Sep 25 23:11:13 2008 UTC
# Line 1  Line 1 
1  /* $Id$ */  
2    /*******************************************************
3    *
4    * Copyright (c) 2003-2008 by University of Queensland
5    * Earth Systems Science Computational Center (ESSCC)
6    * http://www.uq.edu.au/esscc
7    *
8    * Primary Business: Queensland, Australia
9    * Licensed under the Open Software License version 3.0
10    * http://www.opensource.org/licenses/osl-3.0.php
11    *
12    *******************************************************/
13    
14    
15  /**************************************************************/  /**************************************************************/
16    
17  /*   Finley: Mesh: NodeFile */  /*   Finley: Mesh: NodeFile */
# Line 9  Line 22 
22    
23  /**************************************************************/  /**************************************************************/
24    
 /*   Copyrights by ACcESS Australia 2003/04 */  
 /*   Author: gross@access.edu.au */  
 /*   Version: $Id$ */  
   
 /**************************************************************/  
   
 #include "Finley.h"  
25  #include "NodeFile.h"  #include "NodeFile.h"
26    
27  /**************************************************************/  /**************************************************************/
# Line 24  void Finley_NodeFile_copyTable(int offse Line 30  void Finley_NodeFile_copyTable(int offse
30      int i,n;      int i,n;
31      /* check dimension and file size */      /* check dimension and file size */
32      if (out->numDim!=in->numDim) {      if (out->numDim!=in->numDim) {
33          Finley_ErrorCode=TYPE_ERROR;          Finley_setError(TYPE_ERROR,"Finley_NodeFile_copyTable: dimensions of node files don't match");
         sprintf(Finley_ErrorMsg,"dimensions of node files don't match");  
34      }      }
35      if (out->numNodes<in->numNodes+offset) {      if (out->numNodes<in->numNodes+offset) {
36          Finley_ErrorCode=MEMORY_ERROR;          Finley_setError(MEMORY_ERROR,"Finley_NodeFile_copyTable: node table is too small.");
         sprintf(Finley_ErrorMsg,"node table is too small.");  
37      }      }
38      if (Finley_ErrorCode==NO_ERROR) {      if (Finley_noError()) {
39         #pragma omp parallel for private(i,n) schedule(static)         #pragma omp parallel for private(i,n) schedule(static)
40         for(n=0;n<in->numNodes;n++) {         for(n=0;n<in->numNodes;n++) {
41            out->Id[offset+n]=in->Id[n]+idOffset;            out->Id[offset+n]=in->Id[n]+idOffset;
42            out->Tag[offset+n]=in->Tag[n];            out->Tag[offset+n]=in->Tag[n];
43            out->degreeOfFreedom[offset+n]=in->degreeOfFreedom[n]+dofOffset;            out->globalDegreesOfFreedom[offset+n]=in->globalDegreesOfFreedom[n]+dofOffset;
           out->reducedDegreeOfFreedom[offset+n]=in->reducedDegreeOfFreedom[n]+dofOffset;  
           out->toReduced[offset+n]=in->toReduced[n]+dofOffset;  
44            for(i=0;i<out->numDim;i++) out->Coordinates[INDEX2(i,offset+n,out->numDim)]=in->Coordinates[INDEX2(i,n,in->numDim)];            for(i=0;i<out->numDim;i++) out->Coordinates[INDEX2(i,offset+n,out->numDim)]=in->Coordinates[INDEX2(i,n,in->numDim)];
45         }         }
46      }      }
47  }  }
 /*  
 * $Log$  
 * Revision 1.1  2004/10/26 06:53:57  jgs  
 * Initial revision  
 *  
 * Revision 1.1.1.1  2004/06/24 04:00:40  johng  
 * Initial version of eys using boost-python.  
 *  
 *  
 */  

Legend:
Removed from v.82  
changed lines
  Added in v.1811

  ViewVC Help
Powered by ViewVC 1.1.26