|
RTOpPack: Extra C/C++ Code for Vector Reduction/Transformation Operators
Version of the Day
|
00001 /* 00002 // @HEADER 00003 // *********************************************************************** 00004 // 00005 // Moocho: Multi-functional Object-Oriented arCHitecture for Optimization 00006 // Copyright (2003) Sandia Corporation 00007 // 00008 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive 00009 // license for use of this work by or on behalf of the U.S. Government. 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 Roscoe A. Bartlett (rabartl@sandia.gov) 00039 // 00040 // *********************************************************************** 00041 // @HEADER 00042 */ 00043 00044 #include <assert.h> 00045 00046 #include "RTOp_obj_value_vtbl.h" 00047 #include "RTOp_obj_free_free.h" 00048 00049 #include <stdlib.h> 00050 00051 /* Local function definitions */ 00052 00053 static int get_obj_type_num_entries( 00054 const struct RTOp_obj_type_vtbl_t* vtbl 00055 ,const void* instance_data 00056 ,int* num_values 00057 ,int* num_indexes 00058 ,int* num_chars 00059 ) 00060 { 00061 *num_values = 1; 00062 *num_indexes = 0; 00063 *num_chars = 0; 00064 return 0; 00065 } 00066 00067 static int obj_create( 00068 const struct RTOp_obj_type_vtbl_t* vtbl, const void* instance_data, void** obj ) 00069 { 00070 const int mem_size = sizeof(RTOp_value_type); 00071 *obj = malloc( mem_size ); 00072 *((RTOp_value_type*)*obj) = 0.0; 00073 return 0; 00074 } 00075 00076 static int obj_reinit( 00077 const struct RTOp_obj_type_vtbl_t* vtbl, const void* instance_data, void* obj ) 00078 { 00079 *((RTOp_value_type*)obj) = 0.0; 00080 return 0; 00081 } 00082 00083 static int extract_state( 00084 const struct RTOp_obj_type_vtbl_t* vtbl 00085 ,const void * instance_data 00086 ,void * obj 00087 ,int num_values 00088 ,RTOp_value_type value_data[] 00089 ,int num_indexes 00090 ,RTOp_index_type index_data[] 00091 ,int num_chars 00092 ,RTOp_char_type char_data[] 00093 ) 00094 { 00095 assert(obj); 00096 assert( num_values == 1 ); 00097 assert( num_indexes == 0 ); 00098 assert( num_chars == 0 ); 00099 value_data[0] = *((RTOp_value_type*)obj); 00100 return 0; 00101 } 00102 00103 static int load_state( 00104 const struct RTOp_obj_type_vtbl_t* vtbl 00105 ,const void * instance_data 00106 ,int num_values 00107 ,const RTOp_value_type value_data[] 00108 ,int num_indexes 00109 ,const RTOp_index_type index_data[] 00110 ,int num_chars 00111 ,const RTOp_char_type char_data[] 00112 ,void ** obj 00113 ) 00114 { 00115 assert( obj ); 00116 assert( num_values == 1 ); 00117 assert( num_indexes == 0 ); 00118 assert( num_chars == 0 ); 00119 if(*obj == NULL) 00120 obj_create(vtbl,instance_data,obj); 00121 *((RTOp_value_type*)*obj) = value_data[0]; 00122 return 0; 00123 } 00124 00125 const struct RTOp_obj_type_vtbl_t RTOp_obj_value_vtbl = 00126 { 00127 get_obj_type_num_entries 00128 ,obj_create 00129 ,obj_reinit 00130 ,RTOp_obj_free_free 00131 ,extract_state 00132 ,load_state 00133 };
1.7.6.1