|
EpetraExt Development
|
00001 /* 00002 //@HEADER 00003 // *********************************************************************** 00004 // 00005 // EpetraExt: Epetra Extended - Linear Algebra Services Package 00006 // Copyright (2011) Sandia Corporation 00007 // 00008 // Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation, 00009 // the U.S. Government retains certain rights in this software. 00010 // 00011 // Redistribution and use in source and binary forms, with or without 00012 // modification, are permitted provided that the following conditions are 00013 // met: 00014 // 00015 // 1. Redistributions of source code must retain the above copyright 00016 // notice, this list of conditions and the following disclaimer. 00017 // 00018 // 2. Redistributions in binary form must reproduce the above copyright 00019 // notice, this list of conditions and the following disclaimer in the 00020 // documentation and/or other materials provided with the distribution. 00021 // 00022 // 3. Neither the name of the Corporation nor the names of the 00023 // contributors may be used to endorse or promote products derived from 00024 // this software without specific prior written permission. 00025 // 00026 // THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY 00027 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00028 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 00029 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE 00030 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00031 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00032 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00033 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00034 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00035 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00036 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00037 // 00038 // Questions? Contact Michael A. Heroux (maherou@sandia.gov) 00039 // 00040 // *********************************************************************** 00041 //@HEADER 00042 */ 00043 00044 //------------------------------------------------------------------------- 00045 // Filename : $Zoltan_MigrationFunctions.C$ 00046 // 00047 // Purpose : Static methods which are directly registered with 00048 // Zoltan. They us the static container to access 00049 // the dynamic object methods. 00050 // 00051 // Special Notes : 00052 // 00053 // Creator : Robert J. Hoekstra 00054 // 00055 // Creation Date : 08/04/2000 00056 // 00057 // Revision Information: 00058 // --------------------- 00059 // 00060 // Revision Number: $Revision$ 00061 // 00062 // Revision Date : $Date$ 00063 // 00064 // Current Owner : $Author$ 00065 //------------------------------------------------------------------------- 00066 00067 #include <Zoltan_MigrationFunctions.h> 00068 #include <Zoltan_MigrationContainer.h> 00069 #include <Zoltan_MigrationObject.h> 00070 00071 EPETRAEXT_DEPRECATED 00072 int Zoltan::MigrationFunctions::Object_Size ( void * data, 00073 int num_gid_entries, 00074 int num_lid_entries, 00075 ZOLTAN_ID_PTR global_id, 00076 ZOLTAN_ID_PTR local_id, 00077 int * ierr ) 00078 { 00079 Zoltan::MigrationObject * obj_ptr = 00080 Zoltan::MigrationContainer::getMigrationObject( 00081 Zoltan::MigrationContainer::getMigrationID() ); 00082 00083 return obj_ptr->Object_Size( data, num_gid_entries, num_lid_entries, 00084 global_id, local_id, ierr ); 00085 } 00086 00087 EPETRAEXT_DEPRECATED 00088 void Zoltan::MigrationFunctions::Pre_Migrate ( void * data, 00089 int num_gid_entries, 00090 int num_lid_entries, 00091 int num_import, 00092 ZOLTAN_ID_PTR import_global_ids, 00093 ZOLTAN_ID_PTR import_local_ids, 00094 int * import_procs, 00095 int num_export, 00096 ZOLTAN_ID_PTR export_global_ids, 00097 ZOLTAN_ID_PTR export_local_ids, 00098 int * export_procs, 00099 int * ierr ) 00100 { 00101 Zoltan::MigrationObject * obj_ptr = 00102 Zoltan::MigrationContainer::getMigrationObject( 00103 Zoltan::MigrationContainer::getMigrationID() ); 00104 00105 obj_ptr->Pre_Migrate( data, num_gid_entries, num_lid_entries, 00106 num_import, import_global_ids, import_local_ids, 00107 import_procs, num_export, export_global_ids, export_local_ids, 00108 export_procs, ierr ); 00109 } 00110 00111 EPETRAEXT_DEPRECATED 00112 void Zoltan::MigrationFunctions::Mid_Migrate ( void * data, 00113 int num_gid_entries, 00114 int num_lid_entries, 00115 int num_import, 00116 ZOLTAN_ID_PTR import_global_ids, 00117 ZOLTAN_ID_PTR import_local_ids, 00118 int * import_procs, 00119 int num_export, 00120 ZOLTAN_ID_PTR export_global_ids, 00121 ZOLTAN_ID_PTR export_local_ids, 00122 int * export_procs, 00123 int * ierr ) 00124 { 00125 Zoltan::MigrationObject * obj_ptr = 00126 Zoltan::MigrationContainer::getMigrationObject( 00127 Zoltan::MigrationContainer::getMigrationID() ); 00128 00129 obj_ptr->Mid_Migrate( data, num_gid_entries, num_lid_entries, 00130 num_import, import_global_ids, import_local_ids, 00131 import_procs, num_export, export_global_ids, export_local_ids, 00132 export_procs, ierr ); 00133 } 00134 00135 EPETRAEXT_DEPRECATED 00136 void Zoltan::MigrationFunctions::Post_Migrate ( void * data, 00137 int num_gid_entries, 00138 int num_lid_entries, 00139 int num_import, 00140 ZOLTAN_ID_PTR import_global_ids, 00141 ZOLTAN_ID_PTR import_local_ids, 00142 int * import_procs, 00143 int num_export, 00144 ZOLTAN_ID_PTR export_global_ids, 00145 ZOLTAN_ID_PTR export_local_ids, 00146 int * export_procs, 00147 int * ierr ) 00148 { 00149 Zoltan::MigrationObject * obj_ptr = 00150 Zoltan::MigrationContainer::getMigrationObject( 00151 Zoltan::MigrationContainer::getMigrationID() ); 00152 00153 obj_ptr->Post_Migrate( data, num_gid_entries, num_lid_entries, 00154 num_import, import_global_ids, import_local_ids, 00155 import_procs, num_export, export_global_ids, export_local_ids, 00156 export_procs, ierr ); 00157 } 00158 00159 EPETRAEXT_DEPRECATED 00160 void Zoltan::MigrationFunctions::Pack_Object ( void * data, 00161 int num_gid_entries, 00162 int num_lid_entries, 00163 ZOLTAN_ID_PTR global_id, 00164 ZOLTAN_ID_PTR local_id, 00165 int destination_processor, 00166 int size, 00167 char * buffer, 00168 int * ierr ) 00169 { 00170 Zoltan::MigrationObject * obj_ptr = 00171 Zoltan::MigrationContainer::getMigrationObject( 00172 Zoltan::MigrationContainer::getMigrationID() ); 00173 00174 obj_ptr->Pack_Object( data, num_gid_entries, num_lid_entries, 00175 global_id, local_id, destination_processor, size, buffer, ierr ); 00176 } 00177 00178 EPETRAEXT_DEPRECATED 00179 void Zoltan::MigrationFunctions::Unpack_Object ( void * data, 00180 int num_gid_entries, 00181 ZOLTAN_ID_PTR global_id, 00182 int size, 00183 char * buffer, 00184 int * ierr ) 00185 { 00186 Zoltan::MigrationObject * obj_ptr = 00187 Zoltan::MigrationContainer::getMigrationObject( 00188 Zoltan::MigrationContainer::getMigrationID() ); 00189 00190 obj_ptr->Unpack_Object( data, num_gid_entries, global_id, size, 00191 buffer, ierr ); 00192 }
1.7.4