00001 // 菴咲嶌騾イ縺ソ/驕�繧瑚」懷─蝎ィ繧ッ繝ゥ繧ケ 00002 // 2011/02/14 Yuki YOKOKURA 00003 // 00004 // 菴咲嶌陬懷─蝎ィ G(s)=(1+s*a/g)/(1+s/g) (蜿御ク�谺。螟画鋤) 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 PHASELEADLAG 00017 #define PHASELEADLAG 00018 00019 namespace ARCS { // ARCS蜷榊燕遨コ髢� 00020 class PhaseLeadLag { 00021 private: 00022 double Ts; // [s] 蛻カ蠕。蜻ィ譛� 00023 double g; // [rad/s] 繧イ繧、繝ウ迚ケ諤ァ縺ョ謚倥l轤ケ蜻ィ豕「謨ー 00024 double a; // a < 1 縺ァ菴咲嶌驕�繧鯉シ�1 < a 縺ァ菴咲嶌騾イ縺ソ 00025 double uZ1; // 迥カ諷句、画焚1 螟画焚蜷校1縺ョ諢丞袖縺ッz螟画鋤縺ョz^(-1)繧堤、コ縺� 00026 double yZ1; // 迥カ諷句、画焚2 00027 00028 public: 00029 PhaseLeadLag(double AngFreq, double Phase, double SmplTime); 00030 // 繧ウ繝ウ繧ケ繝医Λ繧ッ繧ソ 00031 // AngFreq�シ媼rad/s] 繧イ繧、繝ウ迚ケ諤ァ縺ョ謚倥l轤ケ蜻ィ豕「謨ー�シ径 < 1 縺ァ菴咲嶌驕�繧鯉シ�1 < a 縺ァ菴咲嶌騾イ縺ソ�シ郡mplTime�シ媼s] 蛻カ蠕。蜻ィ譛� 00032 ~PhaseLeadLag(); // 繝�繧ケ繝医Λ繧ッ繧ソ 00033 double GetSignal(double u); // 蜃コ蜉帑ソ。蜿キ縺ョ蜿門セ� u�シ帛�・蜉帑ソ。蜿キ 00034 void SetSmplTime(double SmplTime); // 蛻カ蠕。蜻ィ譛溘�ョ蜀崎ィュ螳� SmplTime�シ媼s] 蛻カ蠕。蜻ィ譛� 00035 void SetFreq(double AngFreq); // 繧イ繧、繝ウ迚ケ諤ァ縺ョ謚倥l轤ケ蜻ィ豕「謨ー縺ョ蜀崎ィュ螳� AngFreq�シ媼rad/s] 謚倥l轤ケ蜻ィ豕「謨ー 00036 void SetPhase(double Phase); // a < 1 縺ァ菴咲嶌驕�繧鯉シ�1 < a 縺ァ菴咲嶌騾イ縺ソ 00037 void ClearStateVars(void); // 縺吶∋縺ヲ縺ョ迥カ諷句、画焚縺ョ繝ェ繧サ繝�繝� 00038 }; 00039 } 00040 00041 #endif 00042 00043 00044