My Project  0.0.16
QUCS Mapping
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
bondwire.h
Go to the documentation of this file.
1 /*
2  * bondwire.h - bondwire class definitions
3  *
4  * Copyright (C) 2006 Bastien Roucaries <roucaries.bastien@gmail.com>
5  * Copyright (C) 2007, 2008 Stefan Jahn <stefan@lkcc.org>
6  *
7  * This is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 2, or (at your option)
10  * any later version.
11  *
12  * This software is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this package; see the file COPYING. If not, write to
19  * the Free Software Foundation, Inc., 51 Franklin Street - Fifth Floor,
20  * Boston, MA 02110-1301, USA.
21  *
22  * $Id: bondwire.h 1825 2011-03-11 20:42:14Z ela $
23  *
24  */
25 
26 #ifndef __BONDWIRE_H__
27 #define __BONDWIRE_H__
28 
29 
30 class bondwire : public circuit
31 {
32  public:
33  CREATOR (bondwire);
34  void initSP (void);
35  void calcSP (const nr_double_t);
36  void calcNoiseSP (nr_double_t);
37  void initDC (void);
38  void initAC (void);
39  void calcAC (nr_double_t);
40  void calcNoiseAC (nr_double_t);
41  matrix calcMatrixY (nr_double_t);
42  void saveCharacteristics (nr_double_t);
43 
44  private:
45  void getProperties (void);
46  nr_double_t resistance (const nr_double_t f) const;
47  nr_double_t Lfreespace (const nr_double_t f) const;
48  nr_double_t Lmirror () const;
49 
50  nr_double_t l;
51  nr_double_t d;
52  nr_double_t h;
53  nr_double_t rho;
54  nr_double_t mur;
55  int model;
56  nr_double_t R, L;
57  nr_double_t temp;
58 };
59 
60 #endif /* __BONDWIRE_H__ */