...
This commit is contained in:
parent
fe6492e4fc
commit
36ffde80f5
@ -14,6 +14,7 @@ namespace mcc
|
|||||||
|
|
||||||
enum class MccSimpleGuidingModelErrorCode : int {
|
enum class MccSimpleGuidingModelErrorCode : int {
|
||||||
ERROR_OK,
|
ERROR_OK,
|
||||||
|
ERROR_CCTE,
|
||||||
ERROR_HW_GETSTATE,
|
ERROR_HW_GETSTATE,
|
||||||
ERROR_HW_SETSTATE,
|
ERROR_HW_SETSTATE,
|
||||||
ERROR_PCM_COMP,
|
ERROR_PCM_COMP,
|
||||||
@ -63,7 +64,17 @@ public:
|
|||||||
|
|
||||||
MccTelemetryData tdata;
|
MccTelemetryData tdata;
|
||||||
MccEqtHrzCoords intsc_coords;
|
MccEqtHrzCoords intsc_coords;
|
||||||
double dist, dx, dy;
|
MccCelestialPoint target_in_future_pt;
|
||||||
|
|
||||||
|
if constexpr (mccIsEquatorialMount(CONTROLS_T::mountType)) {
|
||||||
|
target_in_future_pt.pair_kind = MccCoordPairKind::COORDS_KIND_HADEC_APP;
|
||||||
|
} else if constexpr (mccIsAltAzMount(CONTROLS_T::mountType)) {
|
||||||
|
target_in_future_pt.pair_kind = MccCoordPairKind::COORDS_KIND_AZZD;
|
||||||
|
} else {
|
||||||
|
static_assert(false, "UNKNOW MOUNT TYPE!");
|
||||||
|
}
|
||||||
|
|
||||||
|
// double dist, dx, dy;
|
||||||
|
|
||||||
auto t_err = controls->telemetryData(&tdata);
|
auto t_err = controls->telemetryData(&tdata);
|
||||||
if (t_err) {
|
if (t_err) {
|
||||||
@ -89,8 +100,8 @@ public:
|
|||||||
intsc_coords.Y = intsc_coords.DEC_APP;
|
intsc_coords.Y = intsc_coords.DEC_APP;
|
||||||
} else {
|
} else {
|
||||||
no_intersects = true;
|
no_intersects = true;
|
||||||
intsc_coords.X = tdata.HA + 710.0_mins; // 12h - 10min
|
// intsc_coords.X = tdata.HA + 710.0_mins; // 12h - 10min
|
||||||
intsc_coords.Y = tdata.DEC_APP;
|
// intsc_coords.Y = tdata.DEC_APP;
|
||||||
}
|
}
|
||||||
} else if constexpr (mccIsAltAzMount(CONTROLS_T::mountType)) {
|
} else if constexpr (mccIsAltAzMount(CONTROLS_T::mountType)) {
|
||||||
if (std::isfinite(intsc_coords.AZ)) {
|
if (std::isfinite(intsc_coords.AZ)) {
|
||||||
@ -103,33 +114,97 @@ public:
|
|||||||
static_assert(false, "UNKNOW MOUNT TYPE!");
|
static_assert(false, "UNKNOW MOUNT TYPE!");
|
||||||
}
|
}
|
||||||
|
|
||||||
MccPCMResult pcm_inv_res;
|
// MccPCMResult pcm_inv_res;
|
||||||
|
|
||||||
// endpoint of the mount moving
|
// // endpoint of the mount moving
|
||||||
auto pcm_err = controls->computeInversePCM(intsc_coords, &pcm_inv_res, &hw_state);
|
// auto pcm_err = controls->computeInversePCM(intsc_coords, &pcm_inv_res, &hw_state);
|
||||||
if (pcm_err) {
|
// if (pcm_err) {
|
||||||
return mcc_deduce_error<error_t>(pcm_err, MccSimpleGuidingModelErrorCode::ERROR_PCM_COMP);
|
// return mcc_deduce_error<error_t>(pcm_err, MccSimpleGuidingModelErrorCode::ERROR_PCM_COMP);
|
||||||
}
|
// }
|
||||||
|
|
||||||
if constexpr (mccIsEquatorialMount(CONTROLS_T::mountType)) {
|
// if constexpr (mccIsEquatorialMount(CONTROLS_T::mountType)) {
|
||||||
hw_state.speedX = _currentParams.trackSpeedX;
|
// hw_state.speedX = _currentParams.trackSpeedX;
|
||||||
hw_state.speedY = _currentParams.trackSpeedY;
|
// hw_state.speedY = _currentParams.trackSpeedY;
|
||||||
}
|
// }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
auto target_point = [&, this](MccCelestialPoint* point) {
|
||||||
|
auto dt = std::chrono::duration<double>{tdata.HA} +
|
||||||
|
_currentParams.timeShiftToTargetPoint * mcc_sideral_to_UT1_ratio; // hour seconds
|
||||||
|
|
||||||
|
auto tp_dt = std::chrono::duration_cast<typename decltype(tdata.time_point)::duration>(
|
||||||
|
_currentParams.timeShiftToTargetPoint);
|
||||||
|
|
||||||
|
// point in +time_dist future
|
||||||
|
MccCelestialPoint pt{
|
||||||
|
.pair_kind = MccCoordPairKind::COORDS_KIND_HADEC_APP,
|
||||||
|
.X = MccAngle(dt.count() * std::numbers::pi / 3600.0 / 15.0).normalize<MccAngle::NORM_KIND_0_360>(),
|
||||||
|
.Y = tdata.DEC_APP};
|
||||||
|
mcc_tp2tp(tdata.time_point + tp_dt, pt.time_point);
|
||||||
|
|
||||||
|
point->time_point = pt.time_point;
|
||||||
|
|
||||||
|
// check for prohibited zone
|
||||||
|
if (std::isfinite(intsc_coords.HA)) {
|
||||||
|
bool through_pzone =
|
||||||
|
(intsc_coords.HA - pt.X) <= 0; // must be <= 0 if point in future will be in the zone
|
||||||
|
through_pzone &=
|
||||||
|
(intsc_coords.HA - tdata.HA) > 0; // must be > 0 if point in future was out of the zone
|
||||||
|
|
||||||
|
if (through_pzone) {
|
||||||
|
pt.X = intsc_coords.HA;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
auto ret = controls->transformCoordinates(std::move(pt), point);
|
||||||
|
if (ret) {
|
||||||
|
return mcc_deduce_error<error_t>(ret, MccSimpleGuidingModelErrorCode::ERROR_CCTE);
|
||||||
|
} else {
|
||||||
|
MccPCMResult pcm_inv_res;
|
||||||
|
|
||||||
|
// endpoint of the mount moving
|
||||||
|
auto pcm_err = controls->computeInversePCM(target_in_future_pt, &pcm_inv_res, &hw_state);
|
||||||
|
if (pcm_err) {
|
||||||
|
return mcc_deduce_error<error_t>(pcm_err, MccSimpleGuidingModelErrorCode::ERROR_PCM_COMP);
|
||||||
|
}
|
||||||
|
|
||||||
|
mcc_tp2tp(tdata.time_point, hw_state.time_point);
|
||||||
|
}
|
||||||
|
|
||||||
|
return MccSimpleGuidingModelErrorCode::ERROR_OK;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
auto pz_err = update_pzones_ipoint();
|
auto pz_err = update_pzones_ipoint();
|
||||||
if (pz_err) {
|
if (pz_err) {
|
||||||
return mcc_deduce_error<error_t>(pz_err, MccSimpleGuidingModelErrorCode::ERROR_PZONE_CONTAINER_COMP);
|
return mcc_deduce_error<error_t>(pz_err, MccSimpleGuidingModelErrorCode::ERROR_PZONE_CONTAINER_COMP);
|
||||||
}
|
}
|
||||||
|
|
||||||
hw_state.moving_type = CONTROLS_T::hardware_moving_state_t::HW_MOVE_GUIDING;
|
hw_state.moving_type = CONTROLS_T::hardware_moving_state_t::HW_MOVE_GUIDING;
|
||||||
|
|
||||||
|
{
|
||||||
|
std::lock_guard lock{*_currentParamsMutex};
|
||||||
|
|
||||||
|
auto ccte_err = target_point(&target_in_future_pt);
|
||||||
|
if (ccte_err) {
|
||||||
|
return mcc_deduce_error(ccte_err, MccSimpleGuidingModelErrorCode::ERROR_CCTE);
|
||||||
|
}
|
||||||
|
|
||||||
|
if constexpr (mccIsEquatorialMount(CONTROLS_T::mountType)) {
|
||||||
|
hw_state.speedX = _currentParams.trackSpeedX;
|
||||||
|
hw_state.speedY = _currentParams.trackSpeedY;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// move mount
|
||||||
auto hw_err = controls->hardwareSetState(hw_state);
|
auto hw_err = controls->hardwareSetState(hw_state);
|
||||||
if (hw_err) {
|
if (hw_err) {
|
||||||
return mcc_deduce_error<error_t>(hw_err, MccSimpleGuidingModelErrorCode::ERROR_HW_SETSTATE);
|
return mcc_deduce_error<error_t>(hw_err, MccSimpleGuidingModelErrorCode::ERROR_HW_SETSTATE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
std::chrono::steady_clock::time_point last_corr_tp;
|
std::chrono::steady_clock::time_point last_corr_tp, last_ipzone_update_tp;
|
||||||
|
|
||||||
while (*_stopGuiding) {
|
while (*_stopGuiding) {
|
||||||
// wait for updated telemetry data
|
// wait for updated telemetry data
|
||||||
@ -160,62 +235,28 @@ public:
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
t_err = controls->targetToMountDist(&dist);
|
|
||||||
if (t_err) {
|
|
||||||
return mcc_deduce_error<error_t>(t_err, MccSimpleGuidingModelErrorCode::ERROR_DIST_TELEMETRY);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (*_stopGuiding) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
{
|
||||||
std::lock_guard lock{*_currentParamsMutex};
|
std::lock_guard lock{*_currentParamsMutex};
|
||||||
|
|
||||||
if (dist < _currentParams.guidingCorrectionRange[0] ||
|
|
||||||
dist > _currentParams.guidingCorrectionRange[1]) { // moving with sideral speed
|
|
||||||
|
|
||||||
hw_state.moving_type = CONTROLS_T::hardware_moving_state_t::HW_MOVE_TRACKING;
|
|
||||||
if constexpr (mccIsEquatorialMount(CONTROLS_T::mountType)) {
|
|
||||||
hw_state.speedX = _currentParams.trackSpeedX;
|
|
||||||
hw_state.speedY = _currentParams.trackSpeedY;
|
|
||||||
} else if constexpr (mccIsAltAzMount(CONTROLS_T::mountType)) {
|
|
||||||
static_assert(false, "NOT IMPLEMENTED!");
|
|
||||||
} else {
|
|
||||||
static_assert(false, "UNKNOW MOUNT TYPE!");
|
|
||||||
}
|
|
||||||
|
|
||||||
hw_err = controls->hardwareSetState(hw_state);
|
|
||||||
if (hw_err) {
|
|
||||||
return mcc_deduce_error<error_t>(hw_err, MccSimpleGuidingModelErrorCode::ERROR_HW_SETSTATE);
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
auto now = std::chrono::steady_clock::now();
|
auto now = std::chrono::steady_clock::now();
|
||||||
|
|
||||||
if ((now - last_corr_tp) < _currentParams.guidingMinInterval) {
|
if ((now - last_corr_tp) < _currentParams.guidingMinInterval) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
hw_state.X = tdata.target.X;
|
// update prohibited zones intersection point
|
||||||
|
if ((now - last_ipzone_update_tp) < _currentParams.updatingPZoneInterval) {
|
||||||
if constexpr (mccIsEquatorialMount(CONTROLS_T::mountType)) {
|
pz_err = update_pzones_ipoint();
|
||||||
if (_currentParams.dualAxisGuiding) {
|
if (pz_err) {
|
||||||
hw_state.Y = tdata.target.Y;
|
return mcc_deduce_error<error_t>(
|
||||||
} else { // only along HA-axis
|
pz_err, MccSimpleGuidingModelErrorCode::ERROR_PZONE_CONTAINER_COMP);
|
||||||
hw_state.Y = tdata.Y;
|
|
||||||
}
|
}
|
||||||
} else if constexpr (mccIsAltAzMount(CONTROLS_T::mountType)) {
|
|
||||||
hw_state.Y = tdata.target.Y;
|
|
||||||
} else {
|
|
||||||
static_assert(false, "UNKNOW MOUNT TYPE!");
|
|
||||||
}
|
|
||||||
if (t_err) {
|
|
||||||
return mcc_deduce_error<error_t>(t_err, MccSimpleGuidingModelErrorCode::ERROR_DIFF_TELEMETRY);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
last_corr_tp = now;
|
// compute new target-in-future point
|
||||||
|
auto ccte_err = target_point(&target_in_future_pt);
|
||||||
|
if (ccte_err) {
|
||||||
|
return mcc_deduce_error(ccte_err, MccSimpleGuidingModelErrorCode::ERROR_CCTE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// send corrections
|
// send corrections
|
||||||
|
|||||||
@ -9,7 +9,6 @@
|
|||||||
#include <chrono>
|
#include <chrono>
|
||||||
|
|
||||||
#include "mcc_angle.h"
|
#include "mcc_angle.h"
|
||||||
#include "mcc_defaults.h"
|
|
||||||
#include "mcc_generics.h"
|
#include "mcc_generics.h"
|
||||||
|
|
||||||
namespace mcc
|
namespace mcc
|
||||||
@ -58,6 +57,8 @@ struct MccSimpleMovingModelParams {
|
|||||||
double trackSpeedX{};
|
double trackSpeedX{};
|
||||||
double trackSpeedY{};
|
double trackSpeedY{};
|
||||||
|
|
||||||
|
// time shift into future to compute target position in future (UT1-scale time duration)
|
||||||
|
std::chrono::duration<double> timeShiftToTargetPoint{10.0};
|
||||||
|
|
||||||
// ******* guiding mode *******
|
// ******* guiding mode *******
|
||||||
|
|
||||||
@ -141,22 +142,5 @@ typename PZoneContT::error_t mcc_find_closest_pzone(PZoneContT* pz_cont,
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto mcc_compute_target_point(mcc_ccte_c auto const& ccte,
|
|
||||||
mcc_telemetry_c auto const& tdata,
|
|
||||||
traits::mcc_time_duration_c auto const& time_dist,
|
|
||||||
mcc_celestial_point_c auto* point)
|
|
||||||
{
|
|
||||||
auto dt = std::chrono::duration<double>{tdata.HA} + time_dist * mcc_sideral_to_UT1_ratio; // hour seconds
|
|
||||||
|
|
||||||
// point in +time_dist future
|
|
||||||
MccCelestialPoint pt{.pair_kind = point->pair_kind,
|
|
||||||
.time_point = point->time_point + time_dist,
|
|
||||||
.X = dt.count() * std::numbers::pi / 3600.0 / 15.0,
|
|
||||||
.Y = tdata.DEC_APP};
|
|
||||||
|
|
||||||
point->time_point = pt.time_point;
|
|
||||||
|
|
||||||
return ccte.transformCoordinates(std::move(pt), point);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace mcc
|
} // namespace mcc
|
||||||
|
|||||||
@ -439,8 +439,8 @@ public:
|
|||||||
|
|
||||||
ret = _transformCoordinates(pt, &to_pt);
|
ret = _transformCoordinates(pt, &to_pt);
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
point->X = MccAngle(to_pt.X).normalize<MccAngle::NORM_KIND_0_360>();
|
point->X = to_pt.X;
|
||||||
point->Y = MccAngle(to_pt.Y).normalize<MccAngle::NORM_KIND_90_90>();
|
point->Y = to_pt.Y;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -87,15 +87,13 @@ public:
|
|||||||
: _stopSlewing(new std::atomic_bool()), _currentParamsMutex(new std::mutex)
|
: _stopSlewing(new std::atomic_bool()), _currentParamsMutex(new std::mutex)
|
||||||
{
|
{
|
||||||
_slewingFunc = [telemetry, hardware, pz_cont, this]() -> error_t {
|
_slewingFunc = [telemetry, hardware, pz_cont, this]() -> error_t {
|
||||||
*_stopSlewing = false;
|
|
||||||
|
|
||||||
// first, check target coordinates
|
// first, check target coordinates
|
||||||
typename TelemetryT::error_t t_err;
|
typename TelemetryT::error_t t_err;
|
||||||
MccTelemetryData tdata;
|
MccTelemetryData tdata;
|
||||||
|
|
||||||
{
|
{
|
||||||
std::lock_guard lock{*_currentParamsMutex};
|
std::lock_guard lock{*_currentParamsMutex};
|
||||||
t_err = telemetry->waitForTelemetryData(&tdata, _currentParams.telemetryTimeout);
|
t_err = telemetry->telemetryData(&tdata);
|
||||||
|
|
||||||
if (t_err) {
|
if (t_err) {
|
||||||
return mcc_deduce_error<error_t>(t_err, MccSimpleSlewingModelErrorCode::ERROR_GET_TELEMETRY);
|
return mcc_deduce_error<error_t>(t_err, MccSimpleSlewingModelErrorCode::ERROR_GET_TELEMETRY);
|
||||||
@ -332,6 +330,8 @@ public:
|
|||||||
|
|
||||||
error_t slewToTarget()
|
error_t slewToTarget()
|
||||||
{
|
{
|
||||||
|
*_stopSlewing = false;
|
||||||
|
|
||||||
return _slewingFunc();
|
return _slewingFunc();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user