Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Ac simulation #4076

Draft
wants to merge 45 commits into
base: develop
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
c00d04f
Update Bug.md
failiz Feb 5, 2024
0d58769
fixes bug with u simbol. The u symbol should be replaced by a u in ng…
failiz Mar 8, 2023
115ba42
split different options of the spice circuit in sepate lines. Added i…
failiz Mar 12, 2023
600a144
towards transitoty simulations (still work in progress)
failiz Mar 13, 2023
7de4eb7
allow to change properties of the pulse and sinusoidal power supplies
failiz Mar 22, 2023
46bccb8
modified resources.xml to adapt to the new moduleIDs of the new power…
failiz Sep 20, 2023
fc03cb0
added number of cycles as a property to change in pulse power supplies
failiz Sep 20, 2023
be8fac1
fixed bug in loop, removed setElementId to show all the svg elements
failiz Sep 20, 2023
93eedcc
working towards the aligning the oscilloscope signals with the oscill…
failiz Sep 29, 2023
8db3f72
towards multiple oscilloscope in the simulation. Added offset marks t…
failiz Oct 3, 2023
5c2924f
if the negative terminal of a power supply is not connected and there…
failiz Oct 3, 2023
00abb32
handles the 4 channels and adds noise to the signals if the com probe…
failiz Oct 3, 2023
1a4378a
better name for a property
failiz Oct 3, 2023
af0c891
improved oscilloscope in sch view and added axis labels
failiz Oct 4, 2023
a36833f
added axis scale in the oscilloscope for the sch view
failiz Oct 5, 2023
105fd7b
added control of the horizontal simulation to the analysis without lo…
failiz Oct 5, 2023
af0414f
added handling of horizontal positions for multiple oscilloscopes
failiz Oct 6, 2023
433a51a
allow to introduce negative numbers in the properties of parts. This …
failiz Oct 7, 2023
dab2f73
Show the result of the simulation at the end time, not at the startin…
failiz Oct 7, 2023
6e2c3db
In sch view, added the name of the axes to the oscilloscope.
failiz Oct 10, 2023
47ac612
updated position of the labels and axes in the oscilloscope when simu…
failiz Oct 10, 2023
af9e5f6
added properties for the triangular wavegenerator
failiz Oct 10, 2023
b848df3
added some examples for the transitory analysis
failiz Oct 10, 2023
8e1440a
added 555 example
failiz Dec 4, 2023
082736d
Finish wiring of the BB view of the 555 example
failiz Dec 5, 2023
8e7dcd3
added two sketches as examples of the transient simulation
failiz Dec 5, 2023
3ed26cb
fixed oscilloscope text string (too many arguments)
failiz Dec 7, 2023
bfbacda
fixed bug when properties contain capital letters. If so, the propert…
failiz Dec 7, 2023
d258cf5
imprved handling of properties with capital letters
failiz Dec 7, 2023
7684fbd
improved simulation error dialog. Now, there is a scroll area for the…
failiz Dec 7, 2023
a10fdb5
show the right channel in the axis of the oscilloscope (SCH view)
failiz Dec 7, 2023
ef83cec
added properties of the transformer so that users can modifiy its pro…
failiz Dec 7, 2023
3dead91
fixed error when a property does not have symbol: If there is no symb…
failiz Dec 7, 2023
bcf5960
calculate the com voltage at the oscilloscope when there is a wire co…
failiz Dec 8, 2023
cccd30e
First implementation using an animation of the results of the simulat…
failiz Dec 9, 2023
2701e68
now all parts get voltages and currents depending on simulation time
failiz Dec 10, 2023
5d3fc49
Revert elcos
Feb 13, 2024
560f296
Added functionality to set sim frequency and save it to project.
Dec 15, 2023
a70ce54
added the simulation properties to the project properties menu
failiz Feb 18, 2024
4fa9783
added simulator message (sim time) at the top right corner when simul…
failiz Feb 20, 2024
9eb7edb
Added sawtooth generator and modified properties of the triangular si…
failiz Apr 6, 2024
1712697
changed ac poewer supply to sine, added generic pulse power supply an…
failiz Apr 7, 2024
234eb9a
make the transitory simulation not blocking. Results will be shown wh…
failiz Apr 7, 2024
1c56001
added exception for the oscilloscope as it does not have a pcb view
failiz Apr 7, 2024
39b0dad
Load analog code model to have access to current limiting devices for…
failiz May 3, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
added handling of horizontal positions for multiple oscilloscopes
  • Loading branch information
failiz committed Feb 11, 2024
commit af0414f62cdc123b1fd6390c37096ca9560a85ef
53 changes: 33 additions & 20 deletions src/simulation/simulator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -195,25 +195,26 @@ void Simulator::simulate() {
QString spiceNetlist = m_mainWindow->getSpiceNetlist("Simulator Netlist", netList, itemBases);

//Select the type of analysis based on if there is an oscilloscope in the simulation
double maxSimTime = -1, startTime = std::numeric_limits<double>::max();;
m_simEndTime = -1, m_simStartTime = std::numeric_limits<double>::max();;
foreach (ItemBase * item, itemBases) {
if(item->family().toLower().contains("oscilloscope")) {
//TODO: Use TextUtils::convertFromPowerPrefixU function
double time_div = TextUtils::convertFromPowerPrefix(item->getProperty("time/div"), "s");
double pos = TextUtils::convertFromPowerPrefix(item->getProperty("horizontal position"), "s");
std::cout << "Found oscilloscope: time/div: " << item->getProperty("time/div").toStdString() << " " << time_div << item->getProperty("horizontal position").toStdString() << " " << pos << std::endl;
if (pos < startTime) {
startTime = pos;
if (pos < m_simStartTime) {
m_simStartTime = pos;
}
double maxSimTimeOsc = time_div * 10;
if (maxSimTimeOsc > maxSimTime) {
maxSimTime = maxSimTimeOsc;
double maxSimTimeOsc = pos + time_div * 10;
if (maxSimTimeOsc > m_simEndTime) {
m_simEndTime = maxSimTimeOsc;
}
}
}
if (maxSimTime > 0) {
if (m_simEndTime > 0) {
m_simStepTime = (m_simEndTime-m_simStartTime)/Simulator::SimSteps;
//We have found at least one oscilloscope
QString tranAnalysis = QString(".TRAN %1 %2 %3").arg((maxSimTime-startTime)/Simulator::SimSteps).arg(maxSimTime).arg(startTime);
QString tranAnalysis = QString(".TRAN %1 %2 %3").arg(m_simStepTime).arg(m_simEndTime).arg(m_simStartTime);
spiceNetlist.replace(".OP", tranAnalysis);
}

Expand Down Expand Up @@ -610,8 +611,9 @@ std::vector<double> Simulator::voltageVector(ConnectorItem * c0) {
return m_simulator->getVecInfo(net0str.toStdString());
}

QString Simulator::generateSvgPath(std::vector<double> proveVector, std::vector<double> comVector, QString nameId, double verticalScale, double v_offset, double screenHeight, double screenWidth, QString color, QString strokeWidth ) {
std::cout << "VOLTAGE VALUES " << nameId.toStdString() << ": ";
QString Simulator::generateSvgPath(std::vector<double> proveVector, std::vector<double> comVector, QString nameId, double simStartTime, double simTimeStep, double timePos, double timeScale, double verticalScale, double verOffset, double screenHeight, double screenWidth, QString color, QString strokeWidth ) {
std::cout << "OSCILLOSCOPE: pos " << timePos << ", timeScale: " << timeScale << std::endl;
std::cout << "OSCILLOSCOPE: VOLTAGE VALUES " << nameId.toStdString() << ": ";
QString svg;
double screenOffset = 0;//132.87378;
//svg += QString("<rect x='%1' y='%1' width='%2' height='%3' stroke='red' stroke-width='%4'/>\n").arg(screenOffset).arg(screenWidth).arg(screenHeight).arg(strokeWidth);
Expand All @@ -625,20 +627,31 @@ QString Simulator::generateSvgPath(std::vector<double> proveVector, std::vector<
double y_0 = screenOffset + screenHeight/2; // the center of the screen

int points = std::min( proveVector.size(), comVector.size() );
double horScale = screenWidth/(points-1);
for (int i = 0; i < points; i++) {
double voltage = proveVector[i] - comVector[i];
double vPos = (voltage + v_offset) * vScale + y_0;
double oscEndTime = timePos + timeScale * 10;
double nSampleInScreen = (oscEndTime - timePos)/simTimeStep + 1;
double horScale = screenWidth/(nSampleInScreen-1);
std::cout << "OSCILLOSCOPE: nSampleInScreen " << nSampleInScreen << std::endl;
int screenPoint = 0;
for (int vPoint = 0; vPoint < points; vPoint++) {
double time = simStartTime + simTimeStep * vPoint;
if (time < timePos)
continue;
if (time > oscEndTime)
break;

double voltage = proveVector[vPoint] - comVector[vPoint];
double vPos = (voltage + verOffset) * vScale + y_0;
//Do not go out of the screen
vPos = (vPos < screenOffset) ? screenOffset : vPos;
vPos = (vPos > (screenOffset+screenHeight)) ? screenOffset+screenHeight : vPos;

if (i == 0) {
if (screenPoint == 0) {
svg.append("M "+ QString::number(screenOffset, 'f', 3) +" " + QString::number( vPos, 'f', 3) + " ");
} else {
svg.append("L " + QString::number(i*horScale + screenOffset, 'f', 3) + " " + QString::number(vPos, 'f', 3) + " ");
svg.append("L " + QString::number(screenPoint*horScale + screenOffset, 'f', 3) + " " + QString::number(vPos, 'f', 3) + " ");
}
std::cout <<" ("<< i << "): " << voltage << ' ';
std::cout <<" ("<< time << "): " << voltage << ' ';
screenPoint++;
}
svg += "' transform='translate(%1,%2)' stroke='"+ color + "' stroke-width='"+ strokeWidth + "' fill='none' /> \n"; //

Expand Down Expand Up @@ -1372,7 +1385,7 @@ void Simulator::updateOscilloscope(ItemBase * part) {

//Draw the signal
QString pathId = QString("ch%1-path").arg(channel+1);
QString signalPath = generateSvgPath(v, vCom, pathId, divisionSize/voltsDiv[channel], offsets[channel],
QString signalPath = generateSvgPath(v, vCom, pathId, m_simStartTime, m_simStepTime, hPos, timeDiv, divisionSize/voltsDiv[channel], offsets[channel],
screenHeight, screenWidth, lineColor[channel], "20");
bbSvg += signalPath.arg(bbScreenOffset).arg(bbScreenOffset);
schSvg += signalPath.arg(schScreenOffsetX).arg(schScreenOffsetY);
Expand Down Expand Up @@ -1444,13 +1457,13 @@ void Simulator::updateOscilloscope(ItemBase * part) {
std::cout << "SCH SVG Graph is VALID \n" << std::endl;
else
std::cout << "SCH SVG Graph is NOT VALID \n" << std::endl;
std::cout << "SCH SVG: " << schSvg.toStdString() << std::endl;
//std::cout << "SCH SVG: " << schSvg.toStdString() << std::endl;

if(bbGraphRender->isValid())
std::cout << "BB SVG Graph is VALID \n" << std::endl;
else
std::cout << "BB SVG Graph is NOT VALID\n" << std::endl;
std::cout << "BB SVG: " << bbSvg.toStdString() << std::endl;
//std::cout << "BB SVG: " << bbSvg.toStdString() << std::endl;

schGraph->setSharedRenderer(schGraphRender);
schGraph->setZValue(std::numeric_limits<double>::max());
Expand Down
5 changes: 3 additions & 2 deletions src/simulation/simulator.h
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ public slots:
double getVectorValueOrDefault(const std::string & vecName, double defaultValue);
double calculateVoltage(ConnectorItem *, ConnectorItem *);
std::vector<double> voltageVector(ConnectorItem *);
QString generateSvgPath(std::vector<double>, std::vector<double>, QString, double, double, double, double, QString, QString);
QString generateSvgPath(std::vector<double>, std::vector<double>, QString, double, double, double, double, double, double, double, double, QString, QString);
double getCurrent(ItemBase*, QString subpartName="");
double getTransistorCurrent(QString spicePartName, TransistorLeg leg);
double getPower(ItemBase*, QString subpartName="");
Expand All @@ -89,6 +89,7 @@ public slots:
std::shared_ptr<NgSpiceSimulator> m_simulator;
QPointer<class BreadboardSketchWidget> m_breadboardGraphicsView;
QPointer<class SchematicSketchWidget> m_schematicGraphicsView;
double m_simStartTime, m_simStepTime, m_simEndTime;

bool m_enabled = false;

Expand All @@ -99,7 +100,7 @@ public slots:
QTimer *m_simTimer;
static constexpr int SimDelay = 200;
static constexpr double HarmfulNegativeVoltage = -0.5;
static constexpr double SimSteps = 100;
static constexpr double SimSteps = 400;

};

Expand Down