~arcachofo/simulide/1.1.0

« back to all changes in this revision

Viewing changes to src/simulator/elements/passive/e-battery.cpp

  • Committer: arcachofo
  • Date: 2021-01-01 14:23:42 UTC
  • Revision ID: arcachofo@simulide.com-20210101142342-ozfljnll44g5lbl3
Initial Commit 0.5.15-RC3

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/***************************************************************************
 
2
 *   Copyright (C) 2012 by santiago González                               *
 
3
 *   santigoro@gmail.com                                                   *
 
4
 *                                                                         *
 
5
 *   This program is free software; you can redistribute it and/or modify  *
 
6
 *   it under the terms of the GNU General Public License as published by  *
 
7
 *   the Free Software Foundation; either version 2 of the License, or     *
 
8
 *   (at your option) any later version.                                   *
 
9
 *                                                                         *
 
10
 *   This program is distributed in the hope that it will be useful,       *
 
11
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
 
12
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
 
13
 *   GNU General Public License for more details.                          *
 
14
 *                                                                         *
 
15
 *   You should have received a copy of the GNU General Public License     *
 
16
 *   along with this program; if not, see <http://www.gnu.org/licenses/>.  *
 
17
 *                                                                         *
 
18
 ***************************************************************************/
 
19
 
 
20
#include "e-battery.h"
 
21
#include "simulator.h"
 
22
 
 
23
 
 
24
 
 
25
eBattery::eBattery( QString id )
 
26
         : eElement( id )
 
27
{
 
28
    m_volt = 5;
 
29
    m_ePin.resize(2);
 
30
}
 
31
eBattery::~eBattery(){
 
32
    //qDebug() << "eBattery::~eBattery deleting" << QString::fromStdString( m_elmId );
 
33
}
 
34
 
 
35
void eBattery::stamp()
 
36
{
 
37
    m_ePin[0]->setEnodeComp( m_ePin[1]->getEnode() );
 
38
    m_ePin[1]->setEnodeComp( m_ePin[0]->getEnode() );
 
39
    m_ePin[0]->stampAdmitance( 1/cero_doub );
 
40
    m_ePin[1]->stampAdmitance( 1/cero_doub );
 
41
    m_ePin[0]->stampCurrent( m_volt/cero_doub );
 
42
    m_ePin[1]->stampCurrent(-m_volt/cero_doub );
 
43
 
 
44
    //qDebug() << "eBattery::initialize"<<QString::fromStdString(m_elmId)<<m_volt;
 
45
}
 
46
 
 
47
void eBattery::initialize()
 
48
{
 
49
    m_accuracy = Simulator::self()->NLaccuracy();
 
50
    m_lastOut = 0;
 
51
}
 
52
 
 
53
double eBattery::volt()
 
54
 
55
    return m_volt;
 
56
}
 
57
 
 
58
void eBattery::setVolt( double volt )
 
59
{
 
60
    bool pauseSim = Simulator::self()->isRunning();
 
61
    if( pauseSim ) Simulator::self()->pauseSim();
 
62
 
 
63
    if( volt < 1e-12 ) volt = 1e-12;
 
64
    m_volt = volt;
 
65
 
 
66
    if( pauseSim ) Simulator::self()->resumeSim();
 
67
}
 
68