/* * This program source code file is part of KICAD, a free EDA CAD application. * * Copyright (C) 1992-2021 Kicad Developers, see AUTHORS.txt for contributors. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 3 * 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. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . */ #ifndef PCB_CALCULATOR_H #define PCB_CALCULATOR_H #include "transline/transline.h" // Included for SUBST_PRMS_ID definition. #include "transline_ident.h" #include "pcb_calculator_frame_base.h" #include "attenuators/attenuator_classes.h" #include "class_regulator_data.h" extern const wxString PcbCalcDataFileExt; class APP_SETTINGS_BASE; class KIWAY; class PCB_CALCULATOR_SETTINGS; /* * Class PCB_CALCULATOR_FRAME_BASE * This is the main frame for this application */ class PCB_CALCULATOR_FRAME : public PCB_CALCULATOR_FRAME_BASE { public: REGULATOR_LIST m_RegulatorList; // the list of known regulator PCB_CALCULATOR_FRAME( KIWAY* aKiway, wxWindow* aParent ); ~PCB_CALCULATOR_FRAME(); private: // Event handlers void OnClosePcbCalc( wxCloseEvent& event ) override; void OnUpdateUI( wxUpdateUIEvent& event ) override; // Config read-write, virtual from EDA_BASE_FRAME void LoadSettings( APP_SETTINGS_BASE* aCfg ) override; void SaveSettings( APP_SETTINGS_BASE* aCfg ) override; // R/W data files: bool ReadDataFile(); bool WriteDataFile(); /** * @return the full filename of the selected pcb_calculator data file */ const wxString GetDataFilename(); /** * Initialize the full filename of the selected pcb_calculator data file * force the standard extension of the file (.pcbcalc) * @param aFilename = the full filename, with or without extension */ void SetDataFilename( const wxString& aFilename ); /** * Panel-specific initializers */ void initTrackWidthPanel(); void initESeriesPanel(); void initColorCodePanel(); void initViaSizePanel(); /** * Called on calculate button and executes all E-series calculations */ void OnCalculateESeries( wxCommandEvent& event ) override; /** * Radio Buttons to select the E-serie for the resistor calculator * @param event contains the radio button state */ void OnESeriesSelection( wxCommandEvent& event ) override; /** * Function writeTrackWidthConfig * Write Track width parameters in config */ void writeTrackWidthConfig(); /** * Function OnTWParametersChanged * Called when the user changes the general parameters (i.e., anything that * is not one of the controlling values). This update the calculations. */ void OnTWParametersChanged( wxCommandEvent& event ) override; /** * Function OnTWCalculateFromCurrent * Called when the user changes the desired maximum current. This sets the * current as the controlling value and performs the calculations. */ void OnTWCalculateFromCurrent( wxCommandEvent& event ) override; /** * Function OnTWCalculateFromExtWidth * Called when the user changes the desired external trace width. This sets * the external width as the controlling value and performs the calculations. */ void OnTWCalculateFromExtWidth( wxCommandEvent& event ) override; /** * Function OnTWCalculateFromIntWidth * Called when the user changes the desired internal trace width. This sets * the internal width as the controlling value and performs the calculations. */ void OnTWCalculateFromIntWidth( wxCommandEvent& event ) override; /** * Function OnTWResetButtonClick * Called when the user clicks the reset button. This sets * the parameters to their default values. */ void OnTWResetButtonClick( wxCommandEvent& event ) override; /** * Function TWCalculateWidth * Calculate track width required based on given current and temperature rise. */ double TWCalculateWidth( double aCurrent, double aThickness, double aDeltaT_C, bool aUseInternalLayer ); /** * Function TWCalculateCurrent * Calculate maximum current based on given width and temperature rise. */ double TWCalculateCurrent( double aWidth, double aThickness, double aDeltaT_C, bool aUseInternalLayer ); /** * Function TWDisplayValues * Displays the results of a calculation (including resulting values such * as the resistance and power loss). */ void TWDisplayValues( double aCurrent, double aExtWidth, double aIntWidth, double aExtThickness, double aIntThickness ); /** * Function TWUpdateModeDisplay * Updates the fields to show whether the maximum current, external trace * width, or internal trace width is currently the controlling parameter. */ void TWUpdateModeDisplay(); /** * Function writeViaSizeConfig * Write Via Size parameters in config */ void writeViaSizeConfig(); /** * Function OnViaCalculate * Called when the user changes any value in the via calcultor. */ void OnViaCalculate( wxCommandEvent& event ) override; /** * Function OnViaEpsilonR_Button */ void OnViaEpsilonR_Button( wxCommandEvent& event ) override; /** * Function OnViaRho_Button */ void OnViaRho_Button( wxCommandEvent& event ) override; /** * Update the Error message in Via calculation panel */ void onUpdateViaCalcErrorText( wxUpdateUIEvent& event ) override; /** * Function OnViaResetButtonClick * Called when the user clicks the reset button; sets the parameters to their default values. */ void OnViaResetButtonClick( wxCommandEvent& event ) override; /** * Function VSDisplayValues * Displays the results of the calculation. */ void VSDisplayValues( double aViaResistance, double aVoltageDrop, double aPowerLoss, double aEstimatedAmpacity, double aThermalResistance, double aCapacitance, double aTimeDegradation, double aInductance, double aReactance ); // Electrical spacing panel: void OnElectricalSpacingUnitsSelection( wxCommandEvent& event ) override; void OnElectricalSpacingRefresh( wxCommandEvent& event ) override; void ElectricalSpacingUpdateData( double aUnitScale ); /** * Function OnTranslineSelection * Called on new transmission line selection */ void OnTranslineSelection( wxCommandEvent& event ) override; /** * Function OnTransLineResetButtonClick * Called when the user clicks the reset button; sets the parameters to their default values. */ void OnTransLineResetButtonClick( wxCommandEvent& event ) override; /** * Function OnTranslineAnalyse * Run a new analyse for the current transline with current parameters and displays the * electrical parameters */ void OnTranslineAnalyse( wxCommandEvent& event ) override; /** * Function OnTranslineSynthetize * Run a new synthezis for the current transline with current parameters and displays the * geometrical parameters */ void OnTranslineSynthetize( wxCommandEvent& event ) override; /** * Function OnTranslineEpsilonR_Button * Shows a list of current relative dielectric constant(Er) and set the selected value in * main dialog frame */ void OnTranslineEpsilonR_Button( wxCommandEvent& event ) override; /** * Function OnTranslineTanD_Button * Shows a list of current dielectric loss factor (tangent delta) and set the selected value * in main dialog frame */ void OnTranslineTanD_Button( wxCommandEvent& event ) override; /** * Function OnTranslineRho_Button * Shows a list of current Specific resistance list (rho) and set the selected value in main * dialog frame */ void OnTranslineRho_Button( wxCommandEvent& event ) override; /** * Function TranslineTypeSelection * Must be called after selection of a new transline. Update all values, labels and tool * tips of parameters needed by the new transline; irrelevant parameters are blanked. * @param aType = the TRANSLINE_TYPE_ID of the new selected transline */ void TranslineTypeSelection( enum TRANSLINE_TYPE_ID aType ); /** * Function TransfDlgDataToTranslineParams * Read values entered in dialog frame, and transfert these values in current transline * parameters, converted in normalized units */ void TransfDlgDataToTranslineParams(); // Color Code panel void OnToleranceSelection( wxCommandEvent& event ) override; void ToleranceSelection( int aSelection ); // Attenuators Panel void OnAttenuatorSelection( wxCommandEvent& event ) override; void SetAttenuator( unsigned aIdx ); void OnCalculateAttenuator( wxCommandEvent& event ) override; void TransfPanelDataToAttenuator(); void TransfAttenuatorDataToPanel(); void TransfAttenuatorResultsToPanel(); // Regulators Panel void OnRegulatorCalcButtonClick( wxCommandEvent& event ) override; void OnRegulatorResetButtonClick( wxCommandEvent& event ) override; void OnRegulTypeSelection( wxCommandEvent& event ) override; void OnRegulatorSelection( wxCommandEvent& event ) override; void OnDataFileSelection( wxCommandEvent& event ) override; void OnAddRegulator( wxCommandEvent& event ) override; void OnEditRegulator( wxCommandEvent& event ) override; void OnRemoveRegulator( wxCommandEvent& event ) override; /** * Function RegulatorPageUpdate: * Update the regulator page dialog display: * enable the current regulator drawings and the formula used for calculations */ void RegulatorPageUpdate(); /** * Function SelectLastSelectedRegulator * If m_lastSelectedRegulatorName is empty, just calls RegulatorPageUpdate() */ void SelectLastSelectedRegulator(); void RegulatorsSolve(); /** * Write regulators parameters in config * @param aCfg is the config settings */ void Regulators_WriteConfig( PCB_CALCULATOR_SETTINGS* aCfg ); public: // Read/write params values and results /** * Function SetPrmValue * Read/write params values and results * @param aPrmId = param id to write * @param aValue = valmue to write */ void SetPrmValue( enum PRMS_ID aPrmId, double aValue ); /** * Function SetResult * Puts the text into the given result line. * @param aLineNumber = the line (0 to 5) wher to display the text * @param aText = the text to display */ void SetResult( int aLineNumber, const wxString& aText ); /** Function SetPrgmBgColor * Set the background color of a parameter * @param aPrmId = param id to set * @param aCol = new color */ void SetPrmBgColor( enum PRMS_ID aPrmId, const KIGFX::COLOR4D* aCol ); /** * Function GetPrmValue * Returns a param value. * @param aPrmId = param id to write * @return the value always in normalized unit (meter, Hz, Ohm, radian) */ double GetPrmValue( enum PRMS_ID aPrmId ) const; /** * Function IsPrmSelected * @return true if the param aPrmId is selected * Has meaning only for params that have a radio button */ bool IsPrmSelected( enum PRMS_ID aPrmId ) const; // Board classes panel: void OnBoardClassesUnitsSelection( wxCommandEvent& event ) override; void BoardClassesUpdateData( double aUnitScale ); // Calculator doesn't host a tool framework wxWindow* GetToolCanvas() const override { return nullptr; } private: bool m_RegulatorListChanged; // Set when m_RegulatorList is modified and the corresponging file // must be rewritten enum // Which dimension is controlling the track width / current { // calculations: TW_MASTER_CURRENT, // the maximum current, TW_MASTER_EXT_WIDTH, // the external trace width, TW_MASTER_INT_WIDTH // or the internal trace width? } m_TWMode; bool m_TWNested; // Used to stop events caused by setting the answers. enum TRANSLINE_TYPE_ID m_currTransLineType; TRANSLINE* m_currTransLine; std::vector m_transline_list; ATTENUATOR* m_currAttenuator; std::vector m_attenuator_list; wxString m_lastSelectedRegulatorName; wxBitmap* m_ccValueNamesBitmap; wxBitmap* m_ccValuesBitmap; wxBitmap* m_ccMultipliersBitmap; wxBitmap* m_ccTolerancesBitmap; int m_lastNotebookPage; bool m_macHack; }; extern const wxString DataFileNameExt; #endif // PCB_CALCULATOR_H