You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							115 lines
						
					
					
						
							2.9 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							115 lines
						
					
					
						
							2.9 KiB
						
					
					
				| /* | |
|  * This program source code file is part of KiCad, a free EDA CAD application. | |
|  * | |
|  * Copyright (C) 2022 Mikolaj Wielgus | |
|  * Copyright (C) 2022 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, you may find one here: | |
|  * https://www.gnu.org/licenses/gpl-3.0.html | |
|  * or you may search the http://www.gnu.org website for the version 3 license, | |
|  * or you may write to the Free Software Foundation, Inc., | |
|  * 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA | |
|  */ | |
| 
 | |
| #ifndef SIM_MODEL_NGSPICE_H | |
| #define SIM_MODEL_NGSPICE_H | |
|  | |
| #include <sim/sim_model.h> | |
| #include <sim/spice_generator.h> | |
|  | |
| 
 | |
| class SPICE_GENERATOR_NGSPICE : public SPICE_GENERATOR | |
| { | |
| public: | |
|     using SPICE_GENERATOR::SPICE_GENERATOR; | |
| 
 | |
|     std::vector<wxString> CurrentNames( const wxString& aRefName ) const override; | |
| }; | |
| 
 | |
| 
 | |
| class SIM_MODEL_NGSPICE : public SIM_MODEL | |
| { | |
| public: | |
|     friend struct MODEL_INFO_MAP; | |
| 
 | |
| 
 | |
|     SIM_MODEL_NGSPICE( TYPE aType ); | |
| 
 | |
|     bool SetParamFromSpiceCode( const wxString& aParamName, const wxString& aParamValue, | |
|                                 SIM_VALUE_GRAMMAR::NOTATION aNotation ) override; | |
| 
 | |
|     // Protected because it's accessed by QA tests. | |
| protected: | |
|     DEFINE_ENUM_CLASS_WITH_ITERATOR( MODEL_TYPE, | |
|         NONE, | |
|         //RESISTOR, | |
|         //CAPACITOR, | |
|         //INDUCTOR, | |
|         //LTRA, | |
|         //TRANLINE, | |
|         //URC, | |
|         //TRANSLINE, | |
|         //SWITCH, | |
|         //CSWITCH, | |
|         DIODE, | |
|         BJT, | |
|         VBIC, | |
|         HICUM2, | |
|         JFET, | |
|         JFET2, | |
|         MES, | |
|         MESA, | |
|         HFET1, | |
|         HFET2, | |
|         MOS1, | |
|         MOS2, | |
|         MOS3, | |
|         BSIM1, | |
|         BSIM2, | |
|         MOS6, | |
|         BSIM3, | |
|         MOS9, | |
|         B4SOI, | |
|         BSIM4, | |
|         B3SOIFD, | |
|         B3SOIDD, | |
|         B3SOIPD, | |
|         HISIM2, | |
|         HISIMHV1, | |
|         HISIMHV2 | |
|     ) | |
| 
 | |
|     struct MODEL_INFO | |
|     { | |
|         wxString name; | |
|         wxString variant1; | |
|         wxString variant2; | |
|         std::vector<wxString> pinNames; | |
|         wxString description; | |
|         std::vector<SIM_MODEL::PARAM::INFO> modelParams; | |
|         std::vector<SIM_MODEL::PARAM::INFO> instanceParams; | |
|     }; | |
| 
 | |
|     static const MODEL_INFO& ModelInfo( MODEL_TYPE aType ); | |
| 
 | |
| private: | |
|     bool requiresSpiceModelLine() const override { return false; } | |
| 
 | |
|     std::vector<wxString> getPinNames() const override; | |
| 
 | |
|     MODEL_TYPE getModelType() const; | |
|     bool getIsOtherVariant(); | |
| }; | |
| 
 | |
| #endif /* SIM_MODEL_NGSPICE_H */
 |