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 TRANSLINE::calcAnalyze(), TRANSLINE::checkProperties(), TRANSLINE::getProperties(), TRANSLINE::show_results(), and TRANSLINE::showAnalyze().
Referenced by PANEL_TRANSLINE::OnTranslineAnalyse().
|
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 COUPLED_MICROSTRIP::Analyse(), and m_calc.
|
overrideprivatevirtual |
Computation for synthesis.
Reimplemented from TRANSLINE.
Definition at line 41 of file c_microstrip.cpp.
References m_calc, and COUPLED_MICROSTRIP::Synthesize().
|
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, TRANSLINE::m_parameters, MUR_PRM, MURC_PRM, RHO_PRM, TRANSLINE::setErrorLevel(), STRIPLINE_A_PRM, TAND_PRM, TRANSLINE_WARNING, TWISTEDPAIR_EPSILONR_ENV_PRM, and TWISTEDPAIR_TWIST_PRM.
Referenced by TRANSLINE::analyze(), and TRANSLINE::synthesize().
|
staticprotectedinherited |
Converts a TRANSLINE_PARAMETER status to a PCB Calculation status.
Definition at line 449 of file transline.cpp.
References TRANSLINE_ERROR, TRANSLINE_OK, and TRANSLINE_WARNING.
Referenced by showAnalyze(), C_STRIPLINE::showAnalyze(), MICROSTRIP_UI::showAnalyze(), STRIPLINE_UI::showAnalyze(), showSynthesize(), C_STRIPLINE::showSynthesize(), MICROSTRIP_UI::showSynthesize(), and STRIPLINE_UI::showSynthesize().
|
protectedinherited |
Definition at line 321 of file transline.cpp.
References TRANSLINE::ellipke().
Referenced by COPLANAR::calcAnalyze().
|
protectedinherited |
Definition at line 256 of file transline.cpp.
References INFINITY, M_PI_2, and NR_EPSI.
Referenced by TRANSLINE::ellipk().
|
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_PRM, EPSILONR_PRM, FREQUENCY_PRM, TRANSLINE::getProperties(), H_PRM, H_T_PRM, m_calc, TRANSLINE::m_parameters, MURC_PRM, PHYS_LEN_PRM, PHYS_S_PRM, PHYS_WIDTH_PRM, ROUGH_PRM, TRANSLINE_CALCULATION_BASE::SetParameter(), SIGMA_PRM, SKIN_DEPTH_PRM, T_PRM, TAND_PRM, Z0_E_PRM, 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 TRANSLINE::getProperties().
|
inherited |
Definition at line 87 of file transline.cpp.
References KIGFX::COLOR4D::b, EXTRA_PRMS_COUNT, KIGFX::COLOR4D::g, TRANSLINE::m_parameters, TRANSLINE::okCol, and KIGFX::COLOR4D::r.
Referenced by C_MICROSTRIP(), C_STRIPLINE::C_STRIPLINE(), COAX::COAX(), COPLANAR::COPLANAR(), MICROSTRIP_UI::MICROSTRIP_UI(), RECTWAVEGUIDE::RECTWAVEGUIDE(), STRIPLINE_UI::STRIPLINE_UI(), TRANSLINE::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, TRANSLINE::calcAnalyze(), EPSILON_EFF_PRM, FREQUENCY_PRM, TRANSLINE::m_parameters, 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 TRANSLINE::errCol, TRANSLINE::okCol, SetPropertyBgColorInDialog(), TRANSLINE_ERROR, TRANSLINE_WARNING, and TRANSLINE::warnCol.
Referenced by TRANSLINE::checkProperties(), TRANSLINE::getProperties(), showAnalyze(), C_STRIPLINE::showAnalyze(), COAX::showAnalyze(), COPLANAR::showAnalyze(), MICROSTRIP_UI::showAnalyze(), RECTWAVEGUIDE::showAnalyze(), STRIPLINE_UI::showAnalyze(), TWISTEDPAIR::showAnalyze(), 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 showAnalyze(), C_STRIPLINE::showAnalyze(), COAX::showAnalyze(), COPLANAR::showAnalyze(), MICROSTRIP_UI::showAnalyze(), RECTWAVEGUIDE::showAnalyze(), STRIPLINE_UI::showAnalyze(), TWISTEDPAIR::showAnalyze(), 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(), showAnalyze(), C_STRIPLINE::showAnalyze(), MICROSTRIP_UI::showAnalyze(), STRIPLINE_UI::showAnalyze(), 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_PRM, TRANSLINE::convertParameterStatusCode(), TRANSLINE_CALCULATION_BASE::GetAnalysisResults(), m_calc, PHYS_LEN_PRM, PHYS_S_PRM, PHYS_WIDTH_PRM, TRANSLINE::setErrorLevel(), TRANSLINE::setProperty(), TRANSLINE::setResult(), UNIT_MICRON, Z0_E_PRM, and Z0_O_PRM.
|
overrideprivatevirtual |
Shows analysis results and checks for errors / warnings.
Reimplemented from TRANSLINE.
Definition at line 76 of file c_microstrip.cpp.
References ANG_L_PRM, TRANSLINE::convertParameterStatusCode(), TRANSLINE_CALCULATION_BASE::GetAnalysisResults(), m_calc, PHYS_LEN_PRM, PHYS_S_PRM, PHYS_WIDTH_PRM, TRANSLINE::setErrorLevel(), TRANSLINE::setProperty(), TRANSLINE::setResult(), UNIT_MICRON, Z0_E_PRM, and Z0_O_PRM.
|
protectedinherited |
@function skin_depth calculate skin depth
Definition at line 234 of file transline.cpp.
References FREQUENCY_PRM, TRANSLINE::m_parameters, MU0, MURC_PRM, and SIGMA_PRM.
Referenced by COPLANAR::calcAnalyze(), and TRANSLINE::getProperties().
|
virtualinherited |
Definition at line 217 of file transline.cpp.
References TRANSLINE::calcSynthesize(), TRANSLINE::checkProperties(), TRANSLINE::getProperties(), TRANSLINE::show_results(), and TRANSLINE::showSynthesize().
Referenced by PANEL_TRANSLINE::OnTranslineSynthetize().
|
inherited |
Definition at line 128 of file transline.h.
Referenced by TRANSLINE::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_STRIPLINE::C_STRIPLINE(), COAX::COAX(), COPLANAR::COPLANAR(), GROUNDEDCOPLANAR::GROUNDEDCOPLANAR(), MICROSTRIP_UI::MICROSTRIP_UI(), TRANSLINE_IDENT::ReadConfig(), RECTWAVEGUIDE::RECTWAVEGUIDE(), STRIPLINE_UI::STRIPLINE_UI(), TRANSLINE::TRANSLINE(), TWISTEDPAIR::TWISTEDPAIR(), and TRANSLINE_IDENT::WriteConfig().
|
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(), TRANSLINE::checkProperties(), RECTWAVEGUIDE::fc(), RECTWAVEGUIDE::get_rectwaveguide_comp(), RECTWAVEGUIDE::get_rectwaveguide_elec(), RECTWAVEGUIDE::get_rectwaveguide_phys(), RECTWAVEGUIDE::get_rectwaveguide_sub(), TRANSLINE::getProperties(), getProperties(), C_STRIPLINE::getProperties(), MICROSTRIP_UI::getProperties(), STRIPLINE_UI::getProperties(), TRANSLINE::Init(), RECTWAVEGUIDE::kc_square(), RECTWAVEGUIDE::kval_square(), TRANSLINE::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(), TRANSLINE::skin_depth(), and TRANSLINE::TRANSLINE().
|
inherited |
Definition at line 130 of file transline.h.
Referenced by TRANSLINE::Init(), and TRANSLINE::setErrorLevel().
|
inherited |
Definition at line 129 of file transline.h.
Referenced by TRANSLINE::setErrorLevel().