00001 // 2谺。謫ャ莨シ蠕ョ蛻�蝎ィ繧ッ繝ゥ繧ケ 00002 // 2011/02/14 Yuki YOKOKURA 00003 // 00004 // 2谺。謫ャ莨シ蠕ョ蛻�蝎ィ G(s)=s^2*w^2/(s^2 + w/Q*s + w^2) (蜿御ク�谺。螟画鋤) 00005 // 00006 // Copyright (C) 2011 Yuki YOKOKURA 00007 // This program is free software; 00008 // you can redistribute it and/or modify it under the terms of the GNU General Public License 00009 // as published by the Free Software Foundation; either version 3 of the License, or any later version. 00010 // This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; 00011 // without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 00012 // See the GNU General Public License for more details <http://www.gnu.org/licenses/>. 00013 // Besides, you can negotiate about other options of licenses instead of GPL. 00014 // If you would like to get other licenses, please contact us<yuki@katsura.sd.keio.ac.jp>. 00015 00016 #ifndef DIFFERENTIATOR2 00017 #define DIFFERENTIATOR2 00018 00019 namespace ARCS { // ARCS蜷榊燕遨コ髢� 00020 class Differentiator2 { 00021 private: 00022 double Ts; // [s] 蛻カ蠕。蜻ィ譛� 00023 double w; // [rad/s] 謫ャ莨シ蠕ョ蛻�縺ョ蟶ッ蝓� 00024 double Q; // 驪ュ縺� 00025 double uZ1; // 迥カ諷句、画焚1 螟画焚蜷校1縺ョ諢丞袖縺ッz螟画鋤縺ョz^(-1)繧堤、コ縺� 00026 double uZ2; // 迥カ諷句、画焚2 00027 double uZ3; // 迥カ諷句、画焚3 00028 double yZ1; // 迥カ諷句、画焚4 00029 double yZ2; // 迥カ諷句、画焚5 00030 double yZ3; // 迥カ諷句、画焚6 00031 00032 public: 00033 Differentiator2(double Bandwidth, double Sharp, double SmplTime); 00034 // 繧ウ繝ウ繧ケ繝医Λ繧ッ繧ソ Bandwidth�シ媼rad/s] 蟶ッ蝓滂シ郡harp�シ幃強縺包シ郡mplTime�シ媼s] 蛻カ蠕。蜻ィ譛� 00035 ~Differentiator2(); // 繝�繧ケ繝医Λ繧ッ繧ソ 00036 double GetSignal(double u); // 蜃コ蜉帑ソ。蜿キ縺ョ蜿門セ� u�シ帛�・蜉帑ソ。蜿キ 00037 void SetBandwidth(double Bandwidth);// 謫ャ莨シ蠕ョ蛻�縺ョ蟶ッ蝓溘�ョ蜀崎ィュ螳� Bandwidth�シ媼rad/s] 蟶ッ蝓� 00038 void SetSharpness(double Sharp); // 驪ュ縺輔�ョ蜀崎ィュ螳� Sharp�シ幃強縺� 00039 void SetSmplTime(double SmplTime); // 蛻カ蠕。蜻ィ譛溘�ョ蜀崎ィュ螳� SmplTime�シ媼s] 蛻カ蠕。蜻ィ譛� 00040 void ClearStateVars(void); // 縺吶∋縺ヲ縺ョ迥カ諷句、画焚縺ョ繝ェ繧サ繝�繝� 00041 }; 00042 } 00043 00044 #endif 00045 00046 00047