|
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 // This library is free software; you can redistribute it and/or modify 00012 // it under the terms of the GNU Lesser General Public License as 00013 // published by the Free Software Foundation; either version 2.1 of the 00014 // License, or (at your option) any later version. 00015 // 00016 // This library is distributed in the hope that it will be useful, but 00017 // WITHOUT ANY WARRANTY; without even the implied warranty of 00018 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00019 // Lesser General Public License for more details. 00020 // 00021 // You should have received a copy of the GNU Lesser General Public 00022 // License along with this library; if not, write to the Free Software 00023 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 00024 // USA 00025 // Questions? Contact Roscoe A. Bartlett (rabartl@sandia.gov) 00026 // 00027 // *********************************************************************** 00028 // @HEADER 00029 */ 00030 00031 #ifndef RTOP_ROP_MAX_INEQU_VIOL_H 00032 #define RTOP_ROP_MAX_INEQU_VIOL_H 00033 00034 #include "RTOp.h" 00035 00036 #ifdef __cplusplus 00037 extern "C" { 00038 #endif 00039 00059 00061 /* */ 00064 struct RTOp_ROp_max_inequ_viol_reduct_obj_t { 00065 RTOp_value_type max_viol; /*< <tt>max_viol = |v_i-vLU|/(1.0+|v_i|) > 0</tt> */ 00066 RTOp_value_type v_i; /*< <tt>v_i = v(max_viol_i)</tt> */ 00067 RTOp_value_type vLU_i; /*< <tt>vLU_i = vL(i)</tt> or <tt>vU(i)</tt> */ 00068 RTOp_index_type max_viol_i; /*< <tt>max_viol_i > 0</tt> if a inequality is violated */ 00069 RTOp_index_type bnd_type; /*< -1 : LOWER, 0 : EQUALITY, +1 : UPPER */ 00070 }; 00071 00072 /* Virtual function table */ 00073 extern const struct RTOp_RTOp_vtbl_t RTOp_ROp_max_inequ_viol_vtbl; 00074 00075 /* Constructor */ 00076 int RTOp_ROp_max_inequ_viol_construct( struct RTOp_RTOp* op ); 00077 00078 /* Destructor */ 00079 int RTOp_ROp_max_inequ_viol_destroy( struct RTOp_RTOp* op ); 00080 00081 /* Extract the concrete reduction target object from its pointer (handle). */ 00082 struct RTOp_ROp_max_inequ_viol_reduct_obj_t 00083 RTOp_ROp_max_inequ_viol_val(RTOp_ReductTarget targ_obj); 00084 00087 #ifdef __cplusplus 00088 } 00089 #endif 00090 00091 #endif /* RTOP_ROP_MAX_INEQU_VIOL_H */
1.7.4