aboutsummaryrefslogtreecommitdiff
path: root/src/tb/pcm_device_tb.cpp
diff options
context:
space:
mode:
authorClément Zrounba <6691770+clement-z@users.noreply.github.com>2023-09-30 23:06:01 +0200
committerClément Zrounba <6691770+clement-z@users.noreply.github.com>2023-09-30 23:26:46 +0200
commitff9b8bb838ecdfbfc1dc81038fcf3b2a87636982 (patch)
tree21f27be782ce11c6d00b96ce100a2bff88141b2e /src/tb/pcm_device_tb.cpp
downloadspecs-ff9b8bb838ecdfbfc1dc81038fcf3b2a87636982.tar.gz
specs-ff9b8bb838ecdfbfc1dc81038fcf3b2a87636982.zip
Initial release
Diffstat (limited to 'src/tb/pcm_device_tb.cpp')
-rw-r--r--src/tb/pcm_device_tb.cpp129
1 files changed, 129 insertions, 0 deletions
diff --git a/src/tb/pcm_device_tb.cpp b/src/tb/pcm_device_tb.cpp
new file mode 100644
index 0000000..b279e6c
--- /dev/null
+++ b/src/tb/pcm_device_tb.cpp
@@ -0,0 +1,129 @@
+#include <ctime>
+#include <iomanip>
+#include <tb/pcm_device_tb.h>
+
+#include "general_utils.h"
+
+void PCMElement_tb::run_1()
+{
+ IN->write(OpticalSignal(sqrt(1.0e-3), 1.55e-6));
+ wait(10, SC_MS);
+ IN->write(OpticalSignal(sqrt(2*1e-3), 1.55e-6)); // to 2W
+ wait(10, SC_MS);
+ IN->write(OpticalSignal(0, 1.55e-6));
+ wait(10, SC_MS);
+ IN->write(OpticalSignal(sqrt(1.0e-3), 1.55e-6));
+ wait(10, SC_MS);
+ IN->write(OpticalSignal(sqrt(2*1.0e-3), 1.55e-6));
+ wait(10, SC_MS);
+ IN->write(OpticalSignal(0, 1.55e-6));
+ wait(10, SC_MS);
+ IN->write(OpticalSignal(sqrt(1.0e-3), 1.55e-6));
+
+
+ while (true) { wait(); }
+}
+
+void PCMElement_tb::monitor()
+{
+ unsigned int event_counter = 0;
+ unsigned int success_counter = 0;
+ const unsigned int test_number = 3;
+ while(true)
+ {
+ wait();
+ event_counter++;
+ std::cout << sc_time_stamp() << ":" << std::endl
+ << "\tIN: " << IN->read() << std::endl
+ << "\tOUT: " << OUT->read() << std::endl
+ << "\tCOUNT: " << event_counter << std::endl;
+
+ if(event_counter == 2)
+ {
+ if (is_close(norm(OUT->read().m_field), 0.000850, 1e-8))
+ success_counter++;
+ else
+ {
+ std::cout << "-----------------/! \\---------------" << std::endl;
+ std::cout << "Failure!" << std::endl;
+ std::cout << "Expected 0.850mW as output power!" << std::endl;
+ std::cout << "-----------------/! \\---------------" << std::endl;
+ }
+ }
+ if(event_counter == 8)
+ {
+ if (is_close(norm(OUT->read().m_field), 0.000854758, 1e-8))
+ success_counter++;
+ else
+ {
+ std::cout << "-----------------/! \\---------------" << std::endl;
+ std::cout << "Failure!" << std::endl;
+ std::cout << "Expected 0.854mW as output power!" << std::endl;
+ std::cout << "-----------------/! \\---------------" << std::endl;
+ }
+ }
+ if(event_counter == 14)
+ {
+ if (is_close(norm(OUT->read().m_field), 0.000859495, 1e-8))
+ success_counter++;
+ else
+ {
+ std::cout << "-----------------/! \\---------------" << std::endl;
+ std::cout << "Failure!" << std::endl;
+ std::cout << "Expected 0.859mW as output power!" << std::endl;
+ std::cout << "-----------------/! \\---------------" << std::endl;
+ }
+
+ std::cout << "-----------------/! \\---------------" << std::endl;
+ std::cout << "Test finished!" << std::endl;
+ std::cout << "Success rate: " << success_counter << "/" << test_number << std::endl;
+ std::cout << "-----------------/! \\---------------" << std::endl;
+ }
+ }
+}
+
+void PCMElement_tb_run()
+{
+ // Apply SPECS resolution before creating any device
+ specsGlobalConfig.applyEngineResolution();
+
+ spx::oa_signal_type IN, OUT;
+
+ PCMElement pcm("pcm", 25e-6, 63, 0);
+ pcm.p_in(IN);
+ pcm.p_out(OUT);
+
+ PCMElement_tb tb("tb");
+ tb.IN(IN);
+ tb.OUT(OUT);
+
+ // Open Trace file
+
+ std::string trace_filename = "traces/";
+ trace_filename += "pcm_device_tb";
+ specsGlobalConfig.trace_filename = trace_filename;
+
+ Probe probe_in("in",specsGlobalConfig.default_trace_file);
+ probe_in.p_in(IN);
+
+ Probe probe_out("out",specsGlobalConfig.default_trace_file);
+ probe_out.p_in(OUT);
+
+ // Apply SPECS options specific to the testbench
+ specsGlobalConfig.simulation_mode = OpticalOutputPortMode::EVENT_DRIVEN;
+ specsGlobalConfig.trace_all_optical_nets = 0;
+
+ // Run SPECS pre-simulation code
+ specsGlobalConfig.prepareSimulation();
+
+ // extra traces should come after prepareSimulation
+ sc_trace(specsGlobalConfig.default_trace_file, pcm.m_state, "STATE");
+
+ // Start simulation
+ sc_start();
+
+ std::cout << std::endl << std::endl;
+ std::cout << ".vcd trace file: " << specsGlobalConfig.trace_filename << std::endl;
+
+ sc_close_vcd_trace_file(specsGlobalConfig.default_trace_file);
+}