IMpmsm2o Class Reference
[PMSM]

#include <pmsm.h>

Inheritance diagram for IMpmsm2o:

bdm::diffbifn bdm::fnc bdm::bdmroot

List of all members.


Detailed Description

State evolution model for a PMSM drive and its derivative with respect to $x$.

Public Member Functions

void set_parameters (double Rs0, double Ls0, double dt0, double Ypm0, double kp0, double p0, double J0, double Mz0)
 Set mechanical and electrical variables.
vec eval (const vec &x0, const vec &u0)
 Evaluates $f(x0,u0)$.
vec eval2o (const vec &du)
 eval 2nd order Taylor expansion, MUST be used only as a follow up AFTER eval()!!
void dfdx_cond (const vec &x0, const vec &u0, mat &A, bool full=true)
 Evaluates $A=\frac{d}{dx}f(x,u)|_{x0,u0}$ and writes result into A .
void dfdu_cond (const vec &x0, const vec &u0, mat &A, bool full=true)
 Evaluates $A=\frac{d}{du}f(x,u)|_{x0,u0}$ and writes result into A .
vec eval (const vec &cond)
 Evaluates $f(x0,u0)$ (VS: Do we really need common eval? ).
int _dimx () const
 access function
int _dimu () const
 access function
virtual void condition (const vec &val)
 function substitutes given value into an appropriate position
int dimension () const
 access function

Protected Attributes

double Rs
double Ls
double dt
double Ypm
double kp
double p
double J
double Mz
double dia
 store first derivatives for the use in second derivatives
double dib
double dom
double dth
double d2t
 d2t = dt^2/2, cth = cos(th), sth=sin(th)
double cth
double sth
double iam
double ibm
double omm
double thm
double uam
double ubm
RV rvx
 Indentifier of the first rv.
RV rvu
 Indentifier of the second rv.
int dimx
 cache for rvx.count()
int dimu
 cache for rvu.count()
int dimy
 Length of the output vector.

Member Function Documentation

void IMpmsm2o::dfdx_cond ( const vec &  x0,
const vec &  u0,
mat &  A,
bool  full = true 
) [inline, virtual]

Evaluates $A=\frac{d}{dx}f(x,u)|_{x0,u0}$ and writes result into A .

Parameters:
full denotes that even unchanged entries are to be rewritten. When, false only the changed elements are computed.
x0 numeric value of $x$,
u0 numeric value of $u$
A a place where the result will be stored.

Reimplemented from bdm::diffbifn.

void IMpmsm2o::dfdu_cond ( const vec &  x0,
const vec &  u0,
mat &  A,
bool  full = true 
) [inline, virtual]

Evaluates $A=\frac{d}{du}f(x,u)|_{x0,u0}$ and writes result into A .

Parameters:
full denotes that even unchanged entries are to be rewritten. When, false only the changed elements are computed.
x0 numeric value of $x$,
u0 numeric value of $u$
A a place where the result will be stored.

Reimplemented from bdm::diffbifn.


The documentation for this class was generated from the following file:

Generated on Wed Mar 4 18:50:17 2009 for mixpp by  doxygen 1.5.6