mirror of
https://github.com/holub/mame
synced 2025-10-04 08:28:39 +03:00

Renamed cast member of the constants struct to magic to clearly identify magic numbers. Introduced nlconst struct inheriting from plib::constants<nl_fptype> to make code better understandable.
77 lines
1.4 KiB
C++
77 lines
1.4 KiB
C++
// license:GPL-2.0+
|
|
// copyright-holders:Couriersud
|
|
/*
|
|
* nld_4066.c
|
|
*
|
|
*/
|
|
|
|
#include "nld_4066.h"
|
|
|
|
#include "netlist/analog/nlid_twoterm.h"
|
|
#include "netlist/solver/nld_solver.h"
|
|
#include "nlid_system.h"
|
|
|
|
namespace netlist
|
|
{
|
|
namespace devices
|
|
{
|
|
NETLIB_OBJECT(CD4066_GATE)
|
|
{
|
|
NETLIB_CONSTRUCTOR(CD4066_GATE)
|
|
NETLIB_FAMILY("CD4XXX")
|
|
, m_supply(*this, "VDD", "VSS", true)
|
|
, m_R(*this, "R")
|
|
, m_control(*this, "CTL")
|
|
, m_base_r(*this, "BASER", nlconst::magic(270.0))
|
|
{
|
|
}
|
|
|
|
NETLIB_RESETI();
|
|
NETLIB_UPDATEI();
|
|
|
|
private:
|
|
nld_power_pins m_supply;
|
|
analog::NETLIB_SUB(R_base) m_R;
|
|
|
|
analog_input_t m_control;
|
|
param_fp_t m_base_r;
|
|
};
|
|
|
|
NETLIB_RESET(CD4066_GATE)
|
|
{
|
|
// Start in off condition
|
|
// FIXME: is ROFF correct?
|
|
m_R.set_R(nlconst::one() / exec().gmin());
|
|
|
|
}
|
|
|
|
NETLIB_UPDATE(CD4066_GATE)
|
|
{
|
|
nl_fptype sup = (m_supply.VCC() - m_supply.GND());
|
|
nl_fptype low = nlconst::magic(0.45) * sup;
|
|
nl_fptype high = nlconst::magic(0.55) * sup;
|
|
nl_fptype in = m_control() - m_supply.GND();
|
|
nl_fptype rON = m_base_r() * nlconst::magic(5.0) / sup;
|
|
nl_fptype R = -nlconst::one();
|
|
|
|
if (in < low)
|
|
{
|
|
R = nlconst::one() / exec().gmin();
|
|
}
|
|
else if (in > high)
|
|
{
|
|
R = rON;
|
|
}
|
|
if (R > nlconst::zero())
|
|
{
|
|
m_R.update();
|
|
m_R.set_R(R);
|
|
m_R.solve_later();
|
|
}
|
|
}
|
|
|
|
NETLIB_DEVICE_IMPL(CD4066_GATE, "CD4066_GATE", "")
|
|
|
|
} //namespace devices
|
|
} // namespace netlist
|