aboutsummaryrefslogtreecommitdiff
path: root/src/devices/pcm_device.cpp
diff options
context:
space:
mode:
authorClément Zrounba <clement.zrounba@ec-lyon.fr>2023-11-23 18:49:56 +0000
committerClément Zrounba <clement.zrounba@ec-lyon.fr>2023-11-23 18:56:41 +0000
commit36505655a3f8e709b2ea91d43f08b32485d0659f (patch)
treeb656760f99f682ff0c08d6b2387eba07ade5dfed /src/devices/pcm_device.cpp
parent7a6345e2a4068de676e879e79f8c31965ecd0771 (diff)
downloadspecs-36505655a3f8e709b2ea91d43f08b32485d0659f.tar.gz
specs-36505655a3f8e709b2ea91d43f08b32485d0659f.zip
update PCM device and add parameters to parser
Diffstat (limited to 'src/devices/pcm_device.cpp')
-rw-r--r--src/devices/pcm_device.cpp21
1 files changed, 10 insertions, 11 deletions
diff --git a/src/devices/pcm_device.cpp b/src/devices/pcm_device.cpp
index dc018da..f99b0f3 100644
--- a/src/devices/pcm_device.cpp
+++ b/src/devices/pcm_device.cpp
@@ -12,12 +12,14 @@ void PCMElement::on_input_changed()
// setting the transmission for the initial state
update_transmission_local();
-
if (specsGlobalConfig.verbose_component_initialization)
{
cout << name() << ":" << endl;
cout << "Emelt = " << m_meltEnergy*1e9 << " nJ" << endl;
cout << "Nstates = " << m_nStates << "" << endl;
+ cout << "Tc = " << abs(m_Tc) << "W/W" << endl;
+ cout << "Ta = " << abs(m_Ta) << "W/W" << endl;
+ cout << "Initial state = " << m_stateCurrent << "" << endl;
cout << (dynamic_cast<spx::oa_signal_type *>(p_in.get_interface()))->name();
cout << " --> ";
cout << (dynamic_cast<spx::oa_signal_type *>(p_out.get_interface()))->name();
@@ -41,7 +43,7 @@ void PCMElement::on_input_changed()
cur_wavelength_id = s.m_wavelength_id;
m_memory_in[cur_wavelength_id] = s.m_field;
- // Summing powers of all wavelengths
+ // Summing powers of all wavelengths (IGNORE heterodyne effects !)
total_in_power = 0;
for (auto lambdaID_field : m_memory_in)
{
@@ -83,7 +85,7 @@ void PCMElement::on_input_changed()
m_last_pulse_power = total_in_power;
// Write attenuated signal to output
- s *= m_transmission;
+ s *= m_Tcurrent_field;
s.getNewId();
m_out_writer.delayedWrite(s, SC_ZERO_TIME);
@@ -105,7 +107,7 @@ bool PCMElement::phase_change(const vector<pulse_sample_t> &samples, const bool
if (samples.empty())
return true;
- if (sc_time_stamp().to_seconds() - samples.back().first < influence_time_ns*1e-9)
+ if (sc_time_stamp().to_seconds() - samples.back().first < m_influence_time_ns*1e-9)
return true;
if (local)
@@ -119,11 +121,11 @@ bool PCMElement::phase_change(const vector<pulse_sample_t> &samples, const bool
energy_absorbed += samples[i].second * dur_pulse;
}
// if enough energy and not saturated
- if ((energy_absorbed > m_meltEnergy) && (m_state < m_nStates))
+ if ((energy_absorbed > m_meltEnergy) && (m_stateCurrent < m_nStates))
{
// cout << sc_time_stamp() << ": \n\t" << name() << " phase changed with "
// << energy_absorbed*1e6 << " uJ" << endl;
- m_state++;
+ m_stateCurrent++;
// cout << "\tnew state: " << m_state << endl;
update_transmission_local();
}
@@ -139,12 +141,9 @@ bool PCMElement::phase_change(const vector<pulse_sample_t> &samples, const bool
void PCMElement::update_transmission_local()
{
- double sp = 0.85;
- double ep = 0.95;
- double speed = 3;
- m_transmission = sp+(ep-sp)*tanh(speed*m_state/m_nStates);
+ m_Tcurrent = m_Tc+(m_Ta-m_Tc)*tanh(m_speed*m_stateCurrent/m_nStates);
// cout << "\tnew trans_power: " << m_transmission << "- W/W" << endl;
// For field need to do a square root
- m_transmission = sqrt(m_transmission);
+ m_Tcurrent_field = sqrt(m_Tcurrent);
}