130 Commits

Author SHA1 Message Date
Vadim Kuznetsov
07970d566a Remove qucs::SkipEmptyParts 2025-01-03 21:06:41 +03:00
ThomasZecha
62cf2d4bdc New Feature: CDL netlist export
Introduced very basic c++ coding style for the class Schematic and it's
parent-class QucsDoc based on https://google.github.io/styleguide/cppguide.html:
-Prefix class attributes with a_ (much more better readability!)
-Class member initialization via constructor member initialization list
-No public class attributes (where possible with small effort)

Signed-off-by: ThomasZecha <zecha@ihp-microelectronics.com>
2024-11-15 12:39:39 +01:00
ThomasZecha
9d55075db8 New Feature: CDL netlist export
Introduced very basic c++ coding style for the extsimkernels subsystem
based on https://google.github.io/styleguide/cppguide.html:
-Prefix class attributes with a_ (much more better readability!)
-Class member initialization via constructor member initialization list
-No public class attributes

Signed-off-by: ThomasZecha <zecha@ihp-microelectronics.com>
2024-11-15 12:35:05 +01:00
Integral
30f8ddd583
refactor: replace non-empty QString constructors with QStringLiteral() 2024-11-04 15:53:11 +08:00
Vadim Kuznetsov
358ce35d88 Collect libs from .INCLUDE and .LIB devices 2024-06-19 19:31:09 +03:00
Vadim Kuznetsov
6ac212a1be Recursively collect SPICE libraries on top of the netlist 2024-06-19 19:15:22 +03:00
Vadim Kuznetsov
9bbcd9f76b Add default initializer for needsPrefix 2024-06-01 20:00:18 +03:00
ivandi
1bb28ff5bb Fix #682 - Warnings during run-time 2024-04-12 11:50:46 -04:00
ivandi
89ca99f5aa Ignore leading underscore variable names, ex: _net0 2024-02-20 21:40:19 -05:00
ivandi69
afb40a280c
Custom simulation fixes (#581)
* Always apply custom prefix enclosed by '#'

This fixes a regression in #513. If the only simulation is custom
and it contains custom prefixed output, the custom prefix is not applied.

* Parse nutmeg scripts to find used simulations

This avoids prefixing when custom simulations don't conflict.

* Relax regexs to allow variable names that include point

Variable names like h2.out are valid so no reason to restrict them in
custom simulation dialog and scalars print parser.

---------

Co-authored-by: ivandi <ivandi@localhost>
2024-02-18 21:24:20 +03:00
ivandi
406999a963 Do not use static variable in Pole-Zero parser 2024-02-06 21:04:43 -05:00
ivandi
dde098b3e4 Do not use static variable in FOUR parser 2024-02-06 20:22:57 -05:00
ivandi
9ec308c6ab Extract THD % from .FOUR simulation 2024-02-03 12:31:32 -05:00
ivandi
0625e1eaef Always return true in checkDCSimulation, completely fixes #124 2024-01-31 20:39:58 -05:00
ivandi
431c67f474 Ngspice netlist rework, fixes #463 2024-01-30 21:19:43 -05:00
Vadim Kuznetsov
f1a1445022
Merge pull request #435 from ivandi69/parse_print
Add parser for printed scalars output
2024-01-14 17:49:22 +03:00
ivandi
06d93d1d2e Add parser for printed scalars output
In custom simulation one can print measurement or calculation results.
For example 'print a b c d > custom.prn'. The file looks like:
a = a_value
b = b_real,b_imag
etc...
The parser adds theses to the dataset as scalars.
2024-01-06 18:32:26 -05:00
ivandi
270df9ab71 Improve cistom_prefix handling. 2024-01-06 18:03:12 -05:00
ivandi
ce8ef3c4d8 Add support for custom prefix to dataset variables. The prefix is
enclosed between # # in the output file name. If the file name contains
a #custom_prefix# section it will be prepended to the dataset variables.
Useful for custom simulations where one can set multiple simulations and
multiple output files.

Example nutmeg script:
============================
AC DEC 10 1MEG 1G
write custom#ac1#.txt v(out)
destroy all

AC LIN 100 90MEG 110MEG
write custom#ac2#.txt v(out)
destroy all
============================

The dataset will contain:
ac1.ac.v(out) ac1.frequency
ac2.ac.v(out) ac2.frequency

Prevent duplications in simulations QStringList of Ngspice::createNetlist.
With current code if one has two nutmeg scripts both scripts are placed
twice in the control section of the netlist.
2023-12-27 10:41:58 -05:00
Sergei Krasilnikov
1ca2f06a32 fix qt6.6 deprecation 2023-11-27 22:59:34 +03:00
Vadim Kuznetsov
a7a535ade9 Fix empty log on second simulation start 2023-10-03 19:45:22 +03:00
Vadim Kuznetsov
12c7eeaab2 Create .IC from wire labels #291 2023-08-12 17:54:58 +03:00
Krasilnikov Sergey
3c4bd175d1 Merge branch 'current' into 274-redesign-simulator-switch 2023-06-15 12:21:58 +03:00
Vadim Kuznetsov
1062209e80 Show warning on failed create dataset 2023-06-11 11:07:59 +03:00
Krasilnikov Sergey
ea517237a2 combine 2 xyce option 2023-06-05 23:52:53 +03:00
Vadim Kuznetsov
16ebecf6fb Run DC bias simulation if only DC simulation found #271 2023-05-26 13:45:31 +03:00
Vadim Kuznetsov
cb88d46777 Show log during simulation #209 2023-03-11 17:12:02 +03:00
Vadim Kuznetsov
407beebdea Added .lib device #242 2023-03-10 19:49:42 +03:00
Krasilnikov Sergei
05177da97b working with qt6 2023-01-17 13:27:12 +03:00
Krasilnikov Sergey
b70e615020 replace foreach macro 2023-01-15 01:17:09 +03:00
luz paz
10c1ee639c Fix various typos (including documenation)
Found via `codespell -q 3 -S *.ts,./qucs/ChangeLog -L ba,coul,inout,leaded,nd,numer,ro`
2022-07-05 07:08:28 -04:00
Vadim Kuznetsov
57b147feb1 Switch HB dataset parser to STD format parser; fix for #28 2022-03-20 12:55:42 +01:00
Vadim Kuznetsov
c475e3b217 Check if schematic contains only DC sim and show error #78 2022-03-13 16:29:31 +01:00
Vadim Kuznetsov
751ffaed29 Reassemble complex variables when reading Xyce STD 2022-03-13 12:48:03 +01:00
Vadim Kuznetsov
3a3481afeb Fix QString::SkipEmptyParts 2022-02-24 23:45:28 +01:00
Vadim Kuznetsov
89755d6b61 Fix endl and inkscape start 2022-02-24 23:16:43 +01:00
Vadim Kuznetsov
c6003e97af More fixed in paintings 2022-02-23 22:54:50 +01:00
Vadim Kuznetsov
35b5cbc285 Quick fix for .FOUR simulation with Xyce; old circuits are operational 2022-02-18 22:05:43 +01:00
Vadim Kuznetsov
53059f4fed Compiles everything in dialogs, paintings, and extsimkernels 2022-02-14 00:04:11 +01:00
yrrapt
d612d2b438 Added a field to add extra parameters to pass to the simulator executable 2020-02-05 20:39:17 +01:00
Vadim Kuznetzov
1fe9f370ea Make to parse RES-files when sweeping SENS 2017-10-19 18:06:32 +03:00
Vadim Kuznetzov
3d20d8b6da Enabled auto-recognizing of Xyce ParSweep 2017-10-19 17:16:01 +03:00
Vadim Kuznetzov
990f961bac Add HB Parameter Sweep support for Xyce 2017-10-13 13:30:08 +03:00
Vadim Kuznetzov
914de682f6 Implemented operational DC sweep + SENS analysis 2017-09-15 15:47:32 +03:00
Vadim Kuznetzov
ba50076498 First version of DC .SENS (Ngspice) 2017-09-12 17:56:08 +03:00
Vadim Kuznetzov
57c37030b7 Add simple check for ground (issue #18) 2017-04-30 11:04:28 +03:00
Vadim Kuznetzov
a2ff26afe2 Replace colon in varailbles by safe symbol 2017-04-22 15:11:21 +03:00
Vadim Kuznetzov
0ef376acfb Added Include script component
Include script allows to add some custom SPICE code before the schematic
inialization.
2017-03-03 16:09:51 +03:00
Vadim Kuznetzov
f5dfb91aa5 Added .FUNC component
This pseudo-device allows to define user math function. It is transalted
to standard SPICE .FUNC directive and is placed before components
initialization in the netlist.
2017-03-03 14:19:31 +03:00
Vadim Kuznetzov
e6548302a7 Fixed double .subckt addition in nested Subcircuits 2016-10-09 10:34:03 +03:00