Libbarrett
1.2.4
|
00001 /* 00002 Copyright 2009, 2010 Barrett Technology <support@barrett.com> 00003 00004 This file is part of libbarrett. 00005 00006 This version of libbarrett is free software: you can redistribute it 00007 and/or modify it under the terms of the GNU General Public License as 00008 published by the Free Software Foundation, either version 3 of the 00009 License, or (at your option) any later version. 00010 00011 This version of libbarrett is distributed in the hope that it will be 00012 useful, but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00014 GNU General Public License for more details. 00015 00016 You should have received a copy of the GNU General Public License along 00017 with this version of libbarrett. If not, see 00018 <http://www.gnu.org/licenses/>. 00019 00020 Further, non-binding information about licensing is available at: 00021 <http://wiki.barrett.com/libbarrett/wiki/LicenseNotes> 00022 */ 00023 00024 /* 00025 * first_order_filter.h 00026 * 00027 * Created on: Nov 18, 2009 00028 * Author: dc 00029 */ 00030 00031 #ifndef BARRETT_SYSTEMS_FIRST_ORDER_FILTER_H_ 00032 #define BARRETT_SYSTEMS_FIRST_ORDER_FILTER_H_ 00033 00034 00035 #include <Eigen/Core> 00036 #include <libconfig.h++> 00037 00038 #include <barrett/detail/ca_macro.h> 00039 #include <barrett/math/first_order_filter.h> 00040 #include <barrett/systems/abstract/single_io.h> 00041 00042 00043 namespace barrett { 00044 namespace systems { 00045 00046 00047 template<typename T, typename MathTraits = math::Traits<T> > 00048 class FirstOrderFilter : public SingleIO<T, T>, protected math::FirstOrderFilter<T,MathTraits> { 00049 public: 00050 explicit FirstOrderFilter(const std::string& sysName = "FirstOrderFilter"); 00051 explicit FirstOrderFilter(const libconfig::Setting& setting, const std::string& sysName = "FirstOrderFilter"); 00052 virtual ~FirstOrderFilter() { this->mandatoryCleanUp(); } 00053 00054 using math::FirstOrderFilter<T,MathTraits>::setFromConfig; 00055 using math::FirstOrderFilter<T,MathTraits>::setLowPass; 00056 using math::FirstOrderFilter<T,MathTraits>::setHighPass; 00057 using math::FirstOrderFilter<T,MathTraits>::setZPK; 00058 using math::FirstOrderFilter<T,MathTraits>::setIntegrator; 00059 using math::FirstOrderFilter<T,MathTraits>::setParameters; 00060 00061 protected: 00062 virtual void operate(); 00063 00064 virtual void onExecutionManagerChanged() { 00065 SingleIO<T, T>::onExecutionManagerChanged(); // First, call super 00066 getSamplePeriodFromEM(); 00067 } 00068 void getSamplePeriodFromEM(); 00069 00070 private: 00071 DISALLOW_COPY_AND_ASSIGN(FirstOrderFilter); 00072 00073 public: 00074 EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF(MathTraits::RequiresAlignment) 00075 }; 00076 00077 00078 } 00079 } 00080 00081 00082 // include template definitions 00083 #include <barrett/systems/detail/first_order_filter-inl.h> 00084 00085 00086 #endif /* BARRETT_SYSTEMS_FIRST_ORDER_FILTER_H_ */