2014-10-23 17:53:38 +00:00
|
|
|
/*
|
|
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2011-2014 Jean-Pierre Charras
|
2019-05-01 18:57:59 +00:00
|
|
|
* Copyright (C) 2004-2014 KiCad Developers, see AUTHORS.txt for contributors.
|
2014-10-23 17:53:38 +00:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
2019-05-01 18:57:59 +00:00
|
|
|
* as published by the Free Software Foundation; either version 3
|
2014-10-23 17:53:38 +00:00
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
2019-05-01 18:57:59 +00:00
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
2014-10-23 17:53:38 +00:00
|
|
|
*/
|
|
|
|
|
2013-05-26 04:36:44 +00:00
|
|
|
/**
|
|
|
|
* @file transline_ident.cpp
|
|
|
|
*/
|
|
|
|
#include <wx/intl.h>
|
|
|
|
#include <wx/arrstr.h>
|
|
|
|
|
|
|
|
|
|
|
|
// Bitmaps:
|
|
|
|
#include <c_microstrip.xpm>
|
|
|
|
#include <microstrip.xpm>
|
|
|
|
#include <twistedpair.xpm>
|
|
|
|
#include <coax.xpm>
|
|
|
|
#include <cpw.xpm>
|
|
|
|
#include <cpw_back.xpm>
|
|
|
|
#include <stripline.xpm>
|
|
|
|
#include <rectwaveguide.xpm>
|
|
|
|
|
|
|
|
// transline specific functions:
|
|
|
|
#include <transline.h>
|
|
|
|
#include <microstrip.h>
|
|
|
|
#include <coplanar.h>
|
|
|
|
#include <rectwaveguide.h>
|
|
|
|
#include <coax.h>
|
|
|
|
#include <c_microstrip.h>
|
|
|
|
#include <stripline.h>
|
|
|
|
#include <twistedpair.h>
|
|
|
|
|
2020-01-13 01:44:19 +00:00
|
|
|
#include <kiface_i.h>
|
|
|
|
#include <pcb_calculator_settings.h>
|
2013-05-26 04:36:44 +00:00
|
|
|
#include <UnitSelector.h>
|
2020-01-13 01:44:19 +00:00
|
|
|
#include <transline_ident.h>
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
2020-01-10 14:31:00 +00:00
|
|
|
* TRANSLINE_PRM
|
2013-05-26 04:36:44 +00:00
|
|
|
* A class to handle one parameter of transline
|
|
|
|
*/
|
|
|
|
TRANSLINE_PRM::TRANSLINE_PRM( PRM_TYPE aType, PRMS_ID aId,
|
|
|
|
const wxString& aLabel,
|
|
|
|
const wxString& aToolTip,
|
|
|
|
double aValue,
|
|
|
|
bool aConvUnit )
|
|
|
|
{
|
|
|
|
m_Type = aType;
|
|
|
|
m_Id = aId;
|
|
|
|
m_Label = aLabel;
|
|
|
|
m_ToolTip = aToolTip;
|
|
|
|
m_Value = aValue;
|
|
|
|
m_ConvUnit = aConvUnit;
|
|
|
|
m_ValueCtrl = NULL;
|
|
|
|
m_UnitCtrl = NULL;
|
|
|
|
m_UnitSelection = 0;
|
2015-03-04 09:26:00 +00:00
|
|
|
m_NormalizedValue = 0;
|
|
|
|
}
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
double TRANSLINE_PRM::ToUserUnit()
|
|
|
|
{
|
|
|
|
if( m_UnitCtrl && m_ConvUnit )
|
|
|
|
return 1.0 / ( (UNIT_SELECTOR*) m_UnitCtrl )->GetUnitScale();
|
|
|
|
else
|
|
|
|
return 1.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
double TRANSLINE_PRM::FromUserUnit()
|
|
|
|
{
|
|
|
|
if( m_UnitCtrl )
|
|
|
|
return ( (UNIT_SELECTOR*) m_UnitCtrl )->GetUnitScale();
|
|
|
|
else
|
|
|
|
return 1.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
2020-01-10 14:31:00 +00:00
|
|
|
* TRANSLINE_IDENT
|
2013-05-26 04:36:44 +00:00
|
|
|
* A class to handle a list of parameters of a given transline
|
|
|
|
*/
|
|
|
|
|
2014-03-22 08:28:39 +00:00
|
|
|
TRANSLINE_IDENT::TRANSLINE_IDENT( enum TRANSLINE_TYPE_ID aType )
|
2013-05-26 04:36:44 +00:00
|
|
|
{
|
|
|
|
m_Type = aType; // The type of transline handled
|
|
|
|
m_Icon = NULL; // An xpm icon to display in dialogs
|
|
|
|
m_TLine = NULL; // The TRANSLINE itself
|
|
|
|
m_HasPrmSelection = false; // true if selection of parameters must be enabled in dialog menu
|
|
|
|
|
|
|
|
// Add common prms:
|
|
|
|
// Default values are for FR4
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, EPSILONR_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Er" ), _( "Epsilon R: substrate relative dielectric constant" ),
|
2013-05-26 04:36:44 +00:00
|
|
|
4.6, false ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, TAND_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "TanD" ), _( "Tangent delta: dielectric loss factor." ), 2e-2,
|
2013-05-26 04:36:44 +00:00
|
|
|
false ) );
|
|
|
|
|
|
|
|
// Default value is for copper
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, RHO_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Rho" ),
|
2014-10-23 17:53:38 +00:00
|
|
|
_( "Electrical resistivity or specific electrical resistance of conductor (Ohm*meter)" ),
|
2013-05-26 04:36:44 +00:00
|
|
|
1.72e-8, false ) );
|
|
|
|
|
|
|
|
// Default value is in GHz
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_FREQUENCY, FREQUENCY_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Frequency" ), _( "Frequency of the input signal" ), 1.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
2015-08-09 09:03:25 +00:00
|
|
|
|
2013-05-26 04:36:44 +00:00
|
|
|
switch( m_Type )
|
|
|
|
{
|
2014-03-22 08:28:39 +00:00
|
|
|
case MICROSTRIP_TYPE: // microstrip
|
2013-05-26 04:36:44 +00:00
|
|
|
m_TLine = new MICROSTRIP();
|
|
|
|
m_Icon = new wxBitmap( microstrip_xpm );
|
|
|
|
|
2018-04-23 23:27:43 +00:00
|
|
|
m_Messages.Add( _( "ErEff:" ) );
|
|
|
|
m_Messages.Add( _( "Conductor Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Dielectric Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Skin Depth:" ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, H_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"H", _( "Height of Substrate" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, H_T_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"H_t", _( "Height of Box Top" ), 1e20, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, T_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"T", _( "Strip Thickness" ), 0.035, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, ROUGH_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Rough" ), _( "Conductor Roughness" ), 0.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MUR_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "mu Rel S" ),
|
2015-05-09 08:37:50 +00:00
|
|
|
_( "Relative Permeability (mu) of Substrate" ), 1, false ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MURC_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "mu Rel C" ), _( "Relative Permeability (mu) of Conductor" ), 1,
|
2013-05-26 04:36:44 +00:00
|
|
|
false ) );
|
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_WIDTH_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"W", _( "Line Width" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_LEN_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"L", _( "Line Length" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, Z0_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Z0", _( "Characteristic Impedance" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, DUMMY_PRM ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, ANG_L_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Ang_l", _( "Electrical Length" ), 0.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
break;
|
|
|
|
|
2014-03-22 08:28:39 +00:00
|
|
|
case CPW_TYPE: // coplanar waveguide
|
2013-05-26 04:36:44 +00:00
|
|
|
m_TLine = new COPLANAR();
|
|
|
|
m_Icon = new wxBitmap( cpw_xpm );
|
|
|
|
m_HasPrmSelection = true;
|
|
|
|
|
2018-04-23 23:27:43 +00:00
|
|
|
m_Messages.Add( _( "ErEff:" ) );
|
|
|
|
m_Messages.Add( _( "Conductor Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Dielectric Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Skin Depth:" ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, H_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"H", _( "Height of Substrate" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, T_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"T", _( "Strip Thickness" ), 0.035, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MURC_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "mu Rel C" ), _( "Relative Permeability (mu) of Conductor" ), 1,
|
2013-05-26 04:36:44 +00:00
|
|
|
false ) );
|
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_WIDTH_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"W", _( "Line Width" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_S_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"S", _( "Gap Width" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_LEN_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"L", _( "Line Length" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, Z0_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Z0", _( "Characteristic Impedance" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, DUMMY_PRM ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, ANG_L_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Ang_l", _( "Electrical Length" ), 0.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
break;
|
|
|
|
|
2014-03-22 08:28:39 +00:00
|
|
|
case GROUNDED_CPW_TYPE: // grounded coplanar waveguide
|
2013-05-26 04:36:44 +00:00
|
|
|
m_TLine = new GROUNDEDCOPLANAR();
|
|
|
|
m_Icon = new wxBitmap( cpw_back_xpm );
|
|
|
|
m_HasPrmSelection = true;
|
|
|
|
|
2018-04-23 23:27:43 +00:00
|
|
|
m_Messages.Add( _( "ErEff:" ) );
|
|
|
|
m_Messages.Add( _( "Conductor Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Dielectric Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Skin Depth:" ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, H_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"H", _( "Height of Substrate" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, T_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"T", _( "Strip Thickness" ), 0.035, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MURC_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"mu Rel C", _( "Relative Permeability (mu) of Conductor" ), 1,
|
2013-05-26 04:36:44 +00:00
|
|
|
false ) );
|
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_WIDTH_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"W", _( "Line Width" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_S_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"S", _( "Gap Width" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_LEN_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"L", _( "Line Length" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, Z0_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Z0", _( "Characteristic Impedance" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, DUMMY_PRM ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, ANG_L_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Ang_l", _( "Electrical Length" ), 0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
|
2014-03-22 08:28:39 +00:00
|
|
|
case RECTWAVEGUIDE_TYPE: // rectangular waveguide
|
2013-05-26 04:36:44 +00:00
|
|
|
m_TLine = new RECTWAVEGUIDE();
|
|
|
|
m_Icon = new wxBitmap( rectwaveguide_xpm );
|
|
|
|
m_HasPrmSelection = true;
|
|
|
|
|
2018-04-23 23:27:43 +00:00
|
|
|
m_Messages.Add( _( "ZF(H10) = Ey / Hx:" ) );
|
|
|
|
m_Messages.Add( _( "ErEff:" ) );
|
|
|
|
m_Messages.Add( _( "Conductor Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Dielectric Losses:" ) );
|
|
|
|
m_Messages.Add( _( "TE-Modes:" ) );
|
|
|
|
m_Messages.Add( _( "TM-Modes:" ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MUR_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "mu Rel I" ), _( "Relative Permeability (mu) of Insulator" ), 1, false ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MURC_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "mu Rel C" ), _( "Relative Permeability (mu) of Conductor" ), 1,
|
2013-05-26 04:36:44 +00:00
|
|
|
false ) );
|
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_WIDTH_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"a", _( "Width of Waveguide" ), 10.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_S_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"b", _( "Height of Waveguide" ), 5.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_LEN_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"L", _( "Waveguide Length" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, Z0_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Z0", _( "Characteristic Impedance" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, DUMMY_PRM ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, ANG_L_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Ang_l", _( "Electrical Length" ), 0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
break;
|
|
|
|
|
2014-03-22 08:28:39 +00:00
|
|
|
case COAX_TYPE: // coaxial cable
|
2013-05-26 04:36:44 +00:00
|
|
|
m_TLine = new COAX();
|
|
|
|
m_Icon = new wxBitmap( coax_xpm );
|
|
|
|
m_HasPrmSelection = true;
|
|
|
|
|
2018-04-23 23:27:43 +00:00
|
|
|
m_Messages.Add( _( "ErEff:" ) );
|
|
|
|
m_Messages.Add( _( "Conductor Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Dielectric Losses:" ) );
|
|
|
|
m_Messages.Add( _( "TE-Modes:" ) );
|
|
|
|
m_Messages.Add( _( "TM-Modes:" ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MUR_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "mu Rel I" ), _( "Relative Permeability (mu) of Insulator" ), 1, false ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MURC_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "mu Rel C" ), _( "Relative Permeability (mu) of Conductor" ), 1,
|
2013-05-26 04:36:44 +00:00
|
|
|
false ) );
|
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_DIAM_IN_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Din" ), _( "Inner Diameter (conductor)" ), 1.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_DIAM_OUT_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Dout" ), _( "Outer Diameter (insulator)" ), 8.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_LEN_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"L", _( "Line Length" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, Z0_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Z0", _( "Characteristic Impedance" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, DUMMY_PRM ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, ANG_L_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Ang_l", _( "Electrical Length" ), 0.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
break;
|
|
|
|
|
2014-03-22 08:28:39 +00:00
|
|
|
case C_MICROSTRIP_TYPE: // coupled microstrip
|
2013-05-26 04:36:44 +00:00
|
|
|
m_TLine = new C_MICROSTRIP();
|
|
|
|
m_Icon = new wxBitmap( c_microstrip_xpm );
|
|
|
|
m_HasPrmSelection = true;
|
|
|
|
|
2018-04-23 23:27:43 +00:00
|
|
|
m_Messages.Add( _( "ErEff Even:" ) );
|
|
|
|
m_Messages.Add( _( "ErEff Odd:" ) );
|
|
|
|
m_Messages.Add( _( "Conductor Losses Even:" ) );
|
|
|
|
m_Messages.Add( _( "Conductor Losses Odd:" ) );
|
|
|
|
m_Messages.Add( _( "Dielectric Losses Even:" ) );
|
|
|
|
m_Messages.Add( _( "Dielectric Losses Odd:" ) );
|
|
|
|
m_Messages.Add( _( "Skin Depth:" ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, H_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"H", _( "Height of Substrate" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, H_T_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"H_t", _( "Height of Box Top" ), 1e20, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, T_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"T", _( "Strip Thickness" ), 0.035, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, ROUGH_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Rough" ), _( "Conductor Roughness" ), 0.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MURC_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "mu Rel C" ), _( "Relative Permeability (mu) of Conductor" ), 1,
|
2013-05-26 04:36:44 +00:00
|
|
|
false ) );
|
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_WIDTH_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"W", _( "Line Width" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_S_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"S", _( "Gap Width" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_LEN_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"L", _( "Line Length" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, Z0_E_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Zeven" ), _( "Even mode impedance (lines driven by common voltages)" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, Z0_O_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Zodd" ), _( "Odd mode impedance (lines driven by opposite (differential) voltages)" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, ANG_L_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Ang_l", _( "Electrical Length" ), 0.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
break;
|
|
|
|
|
2014-03-22 08:28:39 +00:00
|
|
|
case STRIPLINE_TYPE: // stripline
|
2013-05-26 04:36:44 +00:00
|
|
|
m_TLine = new STRIPLINE();
|
|
|
|
m_Icon = new wxBitmap( stripline_xpm );
|
|
|
|
|
2018-04-23 23:27:43 +00:00
|
|
|
m_Messages.Add( _( "ErEff:" ) );
|
|
|
|
m_Messages.Add( _( "Conductor Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Dielectric Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Skin Depth:" ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, H_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"H", _( "Height of Substrate" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, STRIPLINE_A_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"a", _( "distance between strip and top metal" ), 0.2,
|
2013-05-26 04:36:44 +00:00
|
|
|
true ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, T_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"T", _( "Strip Thickness" ), 0.035, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MURC_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "mu Rel C" ), _( "Relative Permeability (mu) of Conductor" ), 1,
|
2013-05-26 04:36:44 +00:00
|
|
|
false ) );
|
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_WIDTH_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"W", _( "Line Width" ), 0.2, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_LEN_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"L", _( "Line Length" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, Z0_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Z0", _( "Characteristic Impedance" ), 50, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, DUMMY_PRM ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, ANG_L_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Ang_l", _( "Electrical Length" ), 0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
break;
|
|
|
|
|
2014-03-22 08:28:39 +00:00
|
|
|
case TWISTEDPAIR_TYPE: // twisted pair
|
2013-05-26 04:36:44 +00:00
|
|
|
m_TLine = new TWISTEDPAIR();
|
|
|
|
m_Icon = new wxBitmap( twistedpair_xpm );
|
|
|
|
m_HasPrmSelection = true;
|
|
|
|
|
2018-04-23 23:27:43 +00:00
|
|
|
m_Messages.Add( _( "ErEff:" ) );
|
|
|
|
m_Messages.Add( _( "Conductor Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Dielectric Losses:" ) );
|
|
|
|
m_Messages.Add( _( "Skin Depth:" ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, TWISTEDPAIR_TWIST_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Twists" ), _( "Number of Twists per Length" ), 0.0, false ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, MURC_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "mu Rel C" ), _( "Relative Permeability (mu) of Conductor" ), 1,
|
2013-05-26 04:36:44 +00:00
|
|
|
false ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_SUBS, TWISTEDPAIR_EPSILONR_ENV_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "ErEnv" ), _( "Relative Permittivity of Environment" ), 1,
|
2013-05-26 04:36:44 +00:00
|
|
|
false ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_DIAM_IN_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Din" ), _( "Inner Diameter (conductor)" ), 1.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_DIAM_OUT_PRM,
|
2020-08-07 00:09:33 +00:00
|
|
|
_( "Dout" ), _( "Outer Diameter (insulator)" ), 8.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_PHYS, PHYS_LEN_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"L", _( "Cable Length" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, Z0_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Z0", _( "Characteristic Impedance" ), 50.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, DUMMY_PRM ) );
|
|
|
|
AddPrm( new TRANSLINE_PRM( PRM_TYPE_ELEC, ANG_L_PRM,
|
2020-08-07 18:17:07 +00:00
|
|
|
"Ang_l", _( "Electrical Length" ), 0.0, true ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
break;
|
|
|
|
|
2014-03-22 08:28:39 +00:00
|
|
|
case END_OF_LIST_TYPE: // Not really used
|
2013-05-26 04:36:44 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TRANSLINE_IDENT::~TRANSLINE_IDENT()
|
|
|
|
{
|
|
|
|
delete m_TLine;
|
|
|
|
delete m_Icon;
|
2020-01-13 01:44:19 +00:00
|
|
|
|
|
|
|
for( auto& ii : m_prms_List )
|
|
|
|
delete ii;
|
2013-05-26 04:36:44 +00:00
|
|
|
|
|
|
|
m_prms_List.clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-01-13 01:44:19 +00:00
|
|
|
void TRANSLINE_IDENT::ReadConfig()
|
2013-05-26 04:36:44 +00:00
|
|
|
{
|
2020-01-13 01:44:19 +00:00
|
|
|
auto cfg = static_cast<PCB_CALCULATOR_SETTINGS*>( Kiface().KifaceSettings() );
|
|
|
|
std::string name( m_TLine->m_Name );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
2020-01-13 01:44:19 +00:00
|
|
|
if( cfg->m_TransLine.param_values.count( name ) )
|
|
|
|
{
|
|
|
|
wxASSERT( cfg->m_TransLine.param_units.count( name ) );
|
|
|
|
|
|
|
|
for( auto& param : m_prms_List )
|
|
|
|
{
|
2020-08-07 00:09:33 +00:00
|
|
|
std::string id = param->m_Label.ToStdString();
|
2020-01-13 01:44:19 +00:00
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
param->m_Value = cfg->m_TransLine.param_values.at( name ).at( id );
|
|
|
|
param->m_UnitSelection = cfg->m_TransLine.param_units.at( name ).at( id );
|
|
|
|
}
|
|
|
|
catch( ... )
|
|
|
|
{}
|
|
|
|
}
|
|
|
|
}
|
2013-05-26 04:36:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-01-13 01:44:19 +00:00
|
|
|
void TRANSLINE_IDENT::WriteConfig()
|
2013-05-26 04:36:44 +00:00
|
|
|
{
|
2020-01-13 01:44:19 +00:00
|
|
|
auto cfg = static_cast<PCB_CALCULATOR_SETTINGS*>( Kiface().KifaceSettings() );
|
|
|
|
std::string name( m_TLine->m_Name );
|
2013-05-26 04:36:44 +00:00
|
|
|
|
2020-01-13 01:44:19 +00:00
|
|
|
for( auto& param : m_prms_List )
|
|
|
|
{
|
2020-08-07 00:09:33 +00:00
|
|
|
std::string id = param->m_Label.ToStdString();
|
|
|
|
|
|
|
|
if( !std::isfinite( param->m_Value ) )
|
|
|
|
{
|
|
|
|
param->m_Value = 0;
|
|
|
|
}
|
|
|
|
|
2020-01-13 01:44:19 +00:00
|
|
|
cfg->m_TransLine.param_values[ name ][ id ] = param->m_Value;
|
|
|
|
cfg->m_TransLine.param_units[ name ][ id ] = param->m_UnitSelection;
|
|
|
|
}
|
2013-05-26 04:36:44 +00:00
|
|
|
}
|
|
|
|
|