Miind
ConnectionSquaredProduct.hpp
Go to the documentation of this file.
1 // Copyright (c) 2005 - 2012 Marc de Kamps
2 // 2012 David-Matthias Sichau
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
6 //
7 // * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
8 // * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation
9 // and/or other materials provided with the distribution.
10 // * Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software
11 // without specific prior written permission.
12 //
13 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
14 // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY
15 // DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
16 // USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
17 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
18 //
19 #ifndef GEOMLIB_CONNECTIONSQUAREDPRODUCT_CODE_HPP_
20 #define GEOMLIB_CONNECTIONSQUAREDPRODUCT_CODE_HPP_
21 
22 #include <utility>
23 #include <functional>
24 #include <vector>
26 
27 namespace GeomLib {
31 class ConnectionSquaredProduct: public std::binary_function<MPILib::Rate,
32  MPILib::DelayedConnection, double> {
33 public:
34 
41  double operator()(MPILib::Rate connection_first,
42  MPILib::DelayedConnection connection_second) const {
43 
44  double f_node_rate = connection_first;
45  double f_efficacy_squared = connection_second._efficacy
46  * connection_second._efficacy;
47  double f_number = connection_second._number_of_connections;
48 
49  return f_node_rate * f_efficacy_squared * f_number;
50  }
51 };
52 } /* namespace GeomLib */
53 
54 #endif // include guard GEOMLIB_CONNECTIONSQUAREDPRODUCT_CODE_HPP_
double operator()(MPILib::Rate connection_first, MPILib::DelayedConnection connection_second) const
double Rate