From 2ef406196751a469323ed622312df2e7e7b1834b Mon Sep 17 00:00:00 2001 From: marwik15 Date: Mon, 2 May 2022 13:19:13 +0200 Subject: Sine wave changes after CR --- daemon/src/Sinewave.cpp | 15 +++++------ daemon/src/Sinewave.h | 14 +++++----- library/include/hwd.h | 14 +++++----- library/src/sinewave.cpp | 66 ++++++++++++++++++++++++------------------------ 4 files changed, 53 insertions(+), 56 deletions(-) diff --git a/daemon/src/Sinewave.cpp b/daemon/src/Sinewave.cpp index de63553..d1ca5ef 100644 --- a/daemon/src/Sinewave.cpp +++ b/daemon/src/Sinewave.cpp @@ -1,9 +1,7 @@ #include "Sinewave.h" -Sinewave::Sinewave() +Sinewave::Sinewave() : m_start_time{clock::now()} { - m_start_time = std::chrono::high_resolution_clock::now(); - m_amplitude = 11; m_frequency = 10; m_phase = 30; @@ -13,10 +11,10 @@ void Sinewave::apply(AssemblyContext ctx) { ctx.bind("/set_amplitude", [&](double amplitude) { set_amplitude(amplitude); }); ctx.bind("/set_frequency", [&](double frequency) { set_frequency(frequency); }); - ctx.bind("/set_phase", [&](double phase) { set_phase(phase); }); + ctx.bind("/set_phase", [&](double phase) { set_phase(phase); }); ctx.bind("/get_amplitude", [&]() -> double { return get_amplitude(); }); ctx.bind("/get_frequency", [&]() -> double { return get_frequency(); }); - ctx.bind("/get_phase", [&]() -> double { return get_phase(); }); + ctx.bind("/get_phase", [&]() -> double { return get_phase(); }); ctx.bind("/get_point", [&]() -> double { return get_point(); }); } @@ -50,10 +48,9 @@ double Sinewave::get_phase() const return m_phase; } -double Sinewave::get_point() +double Sinewave::get_point() const { - m_current_time = std::chrono::high_resolution_clock::now(); - m_duration_time = m_current_time - m_start_time; + const auto time = clock::now() - m_start_time; - return m_amplitude * sin(2 * 3.14 * m_frequency * m_duration_time.count() + m_phase); + return m_amplitude * sin(2 * M_PI * m_frequency * time.count() + m_phase); } diff --git a/daemon/src/Sinewave.h b/daemon/src/Sinewave.h index d8988ad..d5be732 100644 --- a/daemon/src/Sinewave.h +++ b/daemon/src/Sinewave.h @@ -1,12 +1,13 @@ #pragma once -#include -#include +#include #include #include "Assembly.h" -class Sinewave { +class Sinewave +{ + using clock = std::chrono::high_resolution_clock; public: Sinewave(); @@ -21,13 +22,12 @@ public: double get_frequency() const; double get_phase() const; + double get_point() const; + private: - std::chrono::time_point m_start_time, m_current_time; - std::chrono::duration m_duration_time; + const std::chrono::high_resolution_clock::time_point m_start_time; double m_amplitude; double m_frequency; double m_phase; - - double get_point(); }; diff --git a/library/include/hwd.h b/library/include/hwd.h index 4ea75fa..7374291 100644 --- a/library/include/hwd.h +++ b/library/include/hwd.h @@ -22,13 +22,13 @@ bool write(const std::vector data, std::size_t off); namespace sinewave { - void set_amplitude(double); - void set_frequency(double); - void set_phase(double); - double get_amplitude(); - double get_frequency(); - double get_phase(); - double get_point(); +void set_amplitude(double); +void set_frequency(double); +void set_phase(double); +double get_amplitude(); +double get_frequency(); +double get_phase(); +double get_point(); } // namespace sinewave } // namespace hwd diff --git a/library/src/sinewave.cpp b/library/src/sinewave.cpp index 3a1d8ec..04982df 100644 --- a/library/src/sinewave.cpp +++ b/library/src/sinewave.cpp @@ -6,39 +6,39 @@ namespace hwd { namespace sinewave { - void set_amplitude(double amplitude) - { - get_client().call("sinewave/set_amplitude", amplitude); - } - - void set_frequency(double frequency) - { - get_client().call("sinewave/set_frequency", frequency); - } - - void set_phase(double phase) - { - get_client().call("sinewave/set_phase", phase); - } - - double get_amplitude() - { - return get_client().call("sinewave/get_amplitude").as(); - } - - double get_frequency() - { - return get_client().call("sinewave/get_frequency").as(); - } - - double get_phase() - { - return get_client().call("sinewave/get_phase").as(); - } - - double get_point() { - return get_client().call("sinewave/get_point").as(); - } +void set_amplitude(double amplitude) +{ + get_client().call("sinewave/set_amplitude", amplitude); +} + +void set_frequency(double frequency) +{ + get_client().call("sinewave/set_frequency", frequency); +} + +void set_phase(double phase) +{ + get_client().call("sinewave/set_phase", phase); +} + +double get_amplitude() +{ + return get_client().call("sinewave/get_amplitude").as(); +} + +double get_frequency() +{ + return get_client().call("sinewave/get_frequency").as(); +} + +double get_phase() +{ + return get_client().call("sinewave/get_phase").as(); +} + +double get_point() { + return get_client().call("sinewave/get_point").as(); +} } // namespace sinewave } // namespace hwd -- cgit v1.1