| 
    KiCad PCB EDA Suite
    
   | 
 
#include <c_microstrip.h>
  
Public Member Functions | |
| C_MICROSTRIP () | |
| void | setProperty (enum PRMS_ID aPrmId, double aValue) | 
| double | getProperty (enum PRMS_ID aPrmId) | 
| void | checkProperties () | 
| @function checkProperties   | |
| void | setResult (int, double, const char *) | 
| void | setResult (int, const char *) | 
| bool | isSelected (enum PRMS_ID aPrmId) | 
| void | Init () | 
| virtual void | synthesize () | 
| virtual void | calc () | 
| void | analyze () | 
Public Attributes | |
| const char * | m_Name | 
| KIGFX::COLOR4D | errCol = KIGFX::COLOR4D( 1, 0.63, 0.63, 1 ) | 
| KIGFX::COLOR4D | warnCol = KIGFX::COLOR4D( 1, 1, 0.57, 1 ) | 
| KIGFX::COLOR4D | okCol = KIGFX::COLOR4D( 1, 1, 1, 1 ) | 
Protected Member Functions | |
| bool | minimizeZ0Error1D (double *) | 
| @function minimizeZ0Error1D   | |
| double | skin_depth () | 
| @function skin_depth calculate skin depth   | |
| void | ellipke (double, double &, double &) | 
| double | ellipk (double) | 
| void | setErrorLevel (PRMS_ID, char) | 
| @function setErrorLevel   | |
Static Protected Member Functions | |
| static double | calcUnitPropagationDelay (double epsilonEff) | 
| Calculates the unit propagation delay (in ps/cm) for the given effective dielectric constant.   | |
| static char | convertParameterStatusCode (TRANSLINE_STATUS aStatus) | 
| Converts a TRANSLINE_PARAMETER status to a PCB Calculation status.   | |
Protected Attributes | |
| double | m_parameters [EXTRA_PRMS_COUNT] | 
Private Member Functions | |
| void | calcAnalyze () override | 
| Computation for analysis.   | |
| void | calcSynthesize () override | 
| Computation for synthesis.   | |
| void | showAnalyze () override | 
| Shows synthesis results and checks for errors / warnings.   | |
| void | showSynthesize () override | 
| Shows analysis results and checks for errors / warnings.   | |
| void | show_results () override | 
| Shows results.   | |
| void | getProperties () override | 
| @function getProperties   | |
Private Attributes | |
| COUPLED_MICROSTRIP | m_calc | 
Definition at line 33 of file c_microstrip.h.
| C_MICROSTRIP::C_MICROSTRIP | ( | ) | 
Definition at line 28 of file c_microstrip.cpp.
References TRANSLINE::Init(), and TRANSLINE::m_Name.
      
  | 
  inherited | 
Definition at line 208 of file transline.cpp.
References calcAnalyze(), checkProperties(), getProperties(), show_results(), and showAnalyze().
      
  | 
  inlinevirtualinherited | 
Definition at line 99 of file transline.h.
      
  | 
  overrideprivatevirtual | 
Computation for analysis.
Reimplemented from TRANSLINE.
Definition at line 35 of file c_microstrip.cpp.
References m_calc.
      
  | 
  overrideprivatevirtual | 
Computation for synthesis.
Reimplemented from TRANSLINE.
Definition at line 41 of file c_microstrip.cpp.
      
  | 
  staticprotectedinherited | 
Calculates the unit propagation delay (in ps/cm) for the given effective dielectric constant.
Definition at line 443 of file transline.cpp.
Referenced by COPLANAR::calcAnalyze().
      
  | 
  inherited | 
@function checkProperties
Checks the input parameters (ie: negative length). Does not check for incompatibility between values as this depends on the line shape.
Definition at line 166 of file transline.cpp.
References EPSILONR_PRM, FREQUENCY_PRM, H_PRM, H_T_PRM, m_parameters, MUR_PRM, MURC_PRM, RHO_PRM, setErrorLevel(), STRIPLINE_A_PRM, TAND_PRM, TRANSLINE_WARNING, TWISTEDPAIR_EPSILONR_ENV_PRM, and TWISTEDPAIR_TWIST_PRM.
Referenced by analyze(), and synthesize().
      
  | 
  staticprotectedinherited | 
Converts a TRANSLINE_PARAMETER status to a PCB Calculation status.
Definition at line 449 of file transline.cpp.
References OK, TRANSLINE_ERROR, TRANSLINE_OK, TRANSLINE_WARNING, TS_ERROR, and WARNING.
Referenced by C_MICROSTRIP::showAnalyze(), C_STRIPLINE::showAnalyze(), MICROSTRIP_UI::showAnalyze(), STRIPLINE_UI::showAnalyze(), C_MICROSTRIP::showSynthesize(), C_STRIPLINE::showSynthesize(), MICROSTRIP_UI::showSynthesize(), and STRIPLINE_UI::showSynthesize().
      
  | 
  protectedinherited | 
Definition at line 321 of file transline.cpp.
References ellipke().
Referenced by COPLANAR::calcAnalyze().
      
  | 
  protectedinherited | 
      
  | 
  overrideprivatevirtual | 
@function getProperties
Get all properties from the UI. Computes some extra ones.
Reimplemented from TRANSLINE.
Definition at line 105 of file c_microstrip.cpp.
References ANG_L, ANG_L_PRM, EPSILONR, EPSILONR_PRM, FREQUENCY, FREQUENCY_PRM, TRANSLINE::getProperties(), H, H_PRM, H_T, H_T_PRM, m_calc, TRANSLINE::m_parameters, MURC, MURC_PRM, PHYS_LEN, PHYS_LEN_PRM, PHYS_S, PHYS_S_PRM, PHYS_WIDTH, PHYS_WIDTH_PRM, ROUGH, ROUGH_PRM, SIGMA, SIGMA_PRM, SKIN_DEPTH, SKIN_DEPTH_PRM, T, T_PRM, TAND, TAND_PRM, Z0_E, Z0_E_PRM, Z0_O, and Z0_O_PRM.
      
  | 
  inherited | 
Definition at line 137 of file transline.cpp.
References GetPropertyInDialog().
Referenced by RECTWAVEGUIDE::get_rectwaveguide_comp(), RECTWAVEGUIDE::get_rectwaveguide_elec(), RECTWAVEGUIDE::get_rectwaveguide_phys(), RECTWAVEGUIDE::get_rectwaveguide_sub(), and getProperties().
      
  | 
  inherited | 
Definition at line 87 of file transline.cpp.
References EXTRA_PRMS_COUNT, m_parameters, and okCol.
Referenced by C_MICROSTRIP::C_MICROSTRIP(), C_STRIPLINE::C_STRIPLINE(), COAX::COAX(), COPLANAR::COPLANAR(), MICROSTRIP_UI::MICROSTRIP_UI(), RECTWAVEGUIDE::RECTWAVEGUIDE(), STRIPLINE_UI::STRIPLINE_UI(), TRANSLINE(), and TWISTEDPAIR::TWISTEDPAIR().
      
  | 
  inherited | 
Definition at line 116 of file transline.cpp.
References IsSelectedInDialog().
Referenced by COAX::calcSynthesize(), COPLANAR::calcSynthesize(), TWISTEDPAIR::calcSynthesize(), COAX::showSynthesize(), COPLANAR::showSynthesize(), RECTWAVEGUIDE::showSynthesize(), and TWISTEDPAIR::showSynthesize().
      
  | 
  protectedinherited | 
@function minimizeZ0Error1D
Tries to find a parameter that minimizes the error ( on Z0 ). This function only works with a single parameter. Calls calcAnalyze several times until the error is acceptable. While the error is unnacceptable, changes slightly the parameter.
This function does not change Z0 / Angl_L.
| avar | Parameter to synthesize | 
Definition at line 346 of file transline.cpp.
References ANG_L_PRM, C0, calcAnalyze(), EPSILON_EFF_PRM, FREQUENCY_PRM, m_parameters, M_PI, MAX_ERROR, PHYS_LEN_PRM, and Z0_PRM.
Referenced by COPLANAR::calcSynthesize(), and TWISTEDPAIR::calcSynthesize().
      
  | 
  protectedinherited | 
@function setErrorLevel
set an error / warning level for a given parameter.
| aP | parameter | 
| aErrorLevel | Error level | 
Definition at line 432 of file transline.cpp.
References errCol, okCol, SetPropertyBgColorInDialog(), TRANSLINE_ERROR, TRANSLINE_WARNING, and warnCol.
Referenced by checkProperties(), getProperties(), C_MICROSTRIP::showAnalyze(), C_STRIPLINE::showAnalyze(), COAX::showAnalyze(), COPLANAR::showAnalyze(), MICROSTRIP_UI::showAnalyze(), RECTWAVEGUIDE::showAnalyze(), STRIPLINE_UI::showAnalyze(), TWISTEDPAIR::showAnalyze(), C_MICROSTRIP::showSynthesize(), C_STRIPLINE::showSynthesize(), COAX::showSynthesize(), COPLANAR::showSynthesize(), MICROSTRIP_UI::showSynthesize(), RECTWAVEGUIDE::showSynthesize(), STRIPLINE_UI::showSynthesize(), and TWISTEDPAIR::showSynthesize().
      
  | 
  inherited | 
Definition at line 106 of file transline.cpp.
References SetPropertyInDialog().
Referenced by C_MICROSTRIP::showAnalyze(), C_STRIPLINE::showAnalyze(), COAX::showAnalyze(), COPLANAR::showAnalyze(), MICROSTRIP_UI::showAnalyze(), RECTWAVEGUIDE::showAnalyze(), STRIPLINE_UI::showAnalyze(), TWISTEDPAIR::showAnalyze(), C_MICROSTRIP::showSynthesize(), C_STRIPLINE::showSynthesize(), COAX::showSynthesize(), COPLANAR::showSynthesize(), MICROSTRIP_UI::showSynthesize(), RECTWAVEGUIDE::showSynthesize(), STRIPLINE_UI::showSynthesize(), and TWISTEDPAIR::showSynthesize().
      
  | 
  inherited | 
Definition at line 124 of file transline.cpp.
References SetResultInDialog(), and text.
      
  | 
  inherited | 
Definition at line 130 of file transline.cpp.
References SetResultInDialog(), and text.
Referenced by COAX::show_results(), COPLANAR::show_results(), RECTWAVEGUIDE::show_results(), TWISTEDPAIR::show_results(), C_MICROSTRIP::showAnalyze(), C_STRIPLINE::showAnalyze(), MICROSTRIP_UI::showAnalyze(), STRIPLINE_UI::showAnalyze(), C_MICROSTRIP::showSynthesize(), C_STRIPLINE::showSynthesize(), MICROSTRIP_UI::showSynthesize(), and STRIPLINE_UI::showSynthesize().
      
  | 
  overrideprivatevirtual | 
      
  | 
  overrideprivatevirtual | 
Shows synthesis results and checks for errors / warnings.
Reimplemented from TRANSLINE.
Definition at line 47 of file c_microstrip.cpp.
References ANG_L, ANG_L_PRM, ATTEN_COND_EVEN, ATTEN_COND_ODD, ATTEN_DILECTRIC_EVEN, ATTEN_DILECTRIC_ODD, TRANSLINE::convertParameterStatusCode(), EPSILON_EFF_EVEN, EPSILON_EFF_ODD, m_calc, PHYS_LEN, PHYS_LEN_PRM, PHYS_S, PHYS_S_PRM, PHYS_WIDTH, PHYS_WIDTH_PRM, TRANSLINE::setErrorLevel(), TRANSLINE::setProperty(), TRANSLINE::setResult(), SKIN_DEPTH, UNIT_MICRON, UNIT_PROP_DELAY_EVEN, UNIT_PROP_DELAY_ODD, Z0_E, Z0_E_PRM, Z0_O, Z0_O_PRM, and Z_DIFF.
      
  | 
  overrideprivatevirtual | 
Shows analysis results and checks for errors / warnings.
Reimplemented from TRANSLINE.
Definition at line 76 of file c_microstrip.cpp.
References ANG_L, ANG_L_PRM, ATTEN_COND_EVEN, ATTEN_COND_ODD, ATTEN_DILECTRIC_EVEN, ATTEN_DILECTRIC_ODD, TRANSLINE::convertParameterStatusCode(), EPSILON_EFF_EVEN, EPSILON_EFF_ODD, m_calc, PHYS_LEN, PHYS_LEN_PRM, PHYS_S, PHYS_S_PRM, PHYS_WIDTH, PHYS_WIDTH_PRM, TRANSLINE::setErrorLevel(), TRANSLINE::setProperty(), TRANSLINE::setResult(), SKIN_DEPTH, UNIT_MICRON, UNIT_PROP_DELAY_EVEN, UNIT_PROP_DELAY_ODD, Z0_E, Z0_E_PRM, Z0_O, Z0_O_PRM, and Z_DIFF.
      
  | 
  protectedinherited | 
@function skin_depth calculate skin depth

Definition at line 234 of file transline.cpp.
References FREQUENCY_PRM, m_parameters, M_PI, MU0, MURC_PRM, and SIGMA_PRM.
Referenced by COPLANAR::calcAnalyze(), and getProperties().
      
  | 
  virtualinherited | 
Definition at line 217 of file transline.cpp.
References calcSynthesize(), checkProperties(), getProperties(), show_results(), and showSynthesize().
      
  | 
  inherited | 
Definition at line 128 of file transline.h.
Referenced by setErrorLevel().
      
  | 
  private | 
Definition at line 46 of file c_microstrip.h.
Referenced by calcAnalyze(), calcSynthesize(), getProperties(), showAnalyze(), and showSynthesize().
      
  | 
  inherited | 
Definition at line 86 of file transline.h.
Referenced by C_MICROSTRIP::C_MICROSTRIP(), C_STRIPLINE::C_STRIPLINE(), COAX::COAX(), COPLANAR::COPLANAR(), GROUNDEDCOPLANAR::GROUNDEDCOPLANAR(), MICROSTRIP_UI::MICROSTRIP_UI(), RECTWAVEGUIDE::RECTWAVEGUIDE(), STRIPLINE_UI::STRIPLINE_UI(), TRANSLINE(), and TWISTEDPAIR::TWISTEDPAIR().
      
  | 
  protectedinherited | 
Definition at line 133 of file transline.h.
Referenced by RECTWAVEGUIDE::alphac(), COAX::alphac_coax(), RECTWAVEGUIDE::alphad(), COAX::alphad_coax(), COAX::calcAnalyze(), COPLANAR::calcAnalyze(), RECTWAVEGUIDE::calcAnalyze(), TWISTEDPAIR::calcAnalyze(), COAX::calcSynthesize(), COPLANAR::calcSynthesize(), RECTWAVEGUIDE::calcSynthesize(), TWISTEDPAIR::calcSynthesize(), checkProperties(), RECTWAVEGUIDE::fc(), RECTWAVEGUIDE::get_rectwaveguide_comp(), RECTWAVEGUIDE::get_rectwaveguide_elec(), RECTWAVEGUIDE::get_rectwaveguide_phys(), RECTWAVEGUIDE::get_rectwaveguide_sub(), C_MICROSTRIP::getProperties(), C_STRIPLINE::getProperties(), MICROSTRIP_UI::getProperties(), STRIPLINE_UI::getProperties(), getProperties(), Init(), RECTWAVEGUIDE::kc_square(), RECTWAVEGUIDE::kval_square(), minimizeZ0Error1D(), COAX::show_results(), COPLANAR::show_results(), RECTWAVEGUIDE::show_results(), TWISTEDPAIR::show_results(), COAX::showAnalyze(), COPLANAR::showAnalyze(), RECTWAVEGUIDE::showAnalyze(), TWISTEDPAIR::showAnalyze(), COAX::showSynthesize(), COPLANAR::showSynthesize(), RECTWAVEGUIDE::showSynthesize(), TWISTEDPAIR::showSynthesize(), skin_depth(), and TRANSLINE().
      
  | 
  inherited | 
Definition at line 130 of file transline.h.
Referenced by Init(), and setErrorLevel().
      
  | 
  inherited | 
Definition at line 129 of file transline.h.
Referenced by setErrorLevel().