mirror of
https://github.com/Cyrix126/gupaxx.git
synced 2025-01-05 13:39:26 +00:00
feat: add manual donation level logic
This commit is contained in:
parent
cfe411392d
commit
c18266ec81
4 changed files with 40 additions and 12 deletions
|
@ -177,7 +177,6 @@ impl crate::disk::state::Xvb {
|
||||||
}
|
}
|
||||||
|
|
||||||
if self.mode == XvbMode::ManualDonationLevel {
|
if self.mode == XvbMode::ManualDonationLevel {
|
||||||
ui.radio_value(&mut self.manual_donation_level, ManualDonationLevel::VIP, "VIP");
|
|
||||||
ui.radio_value(&mut self.manual_donation_level, ManualDonationLevel::Donor, "Donor");
|
ui.radio_value(&mut self.manual_donation_level, ManualDonationLevel::Donor, "Donor");
|
||||||
ui.radio_value(&mut self.manual_donation_level, ManualDonationLevel::DonorVIP, "DonorVIP");
|
ui.radio_value(&mut self.manual_donation_level, ManualDonationLevel::DonorVIP, "DonorVIP");
|
||||||
ui.radio_value(&mut self.manual_donation_level, ManualDonationLevel::DonorWhale, "DonorWhale");
|
ui.radio_value(&mut self.manual_donation_level, ManualDonationLevel::DonorWhale, "DonorWhale");
|
||||||
|
|
|
@ -255,7 +255,6 @@ pub enum XvbMode {
|
||||||
|
|
||||||
#[derive(Clone, Eq, PartialEq, Debug, Deserialize, Serialize)]
|
#[derive(Clone, Eq, PartialEq, Debug, Deserialize, Serialize)]
|
||||||
pub enum ManualDonationLevel {
|
pub enum ManualDonationLevel {
|
||||||
VIP,
|
|
||||||
Donor,
|
Donor,
|
||||||
DonorVIP,
|
DonorVIP,
|
||||||
DonorWhale,
|
DonorWhale,
|
||||||
|
@ -407,6 +406,6 @@ impl Default for XvbMode {
|
||||||
|
|
||||||
impl Default for ManualDonationLevel {
|
impl Default for ManualDonationLevel {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self::VIP
|
Self::Donor
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -20,7 +20,7 @@ use crate::{
|
||||||
XVB_ROUND_DONOR_WHALE_MIN_HR, XVB_TIME_ALGO,
|
XVB_ROUND_DONOR_WHALE_MIN_HR, XVB_TIME_ALGO,
|
||||||
};
|
};
|
||||||
|
|
||||||
use super::{PubXvbApi, SamplesAverageHour};
|
use super::{priv_stats::RuntimeDonationLevel, PubXvbApi, SamplesAverageHour};
|
||||||
|
|
||||||
pub(crate) fn calcul_donated_time(
|
pub(crate) fn calcul_donated_time(
|
||||||
lhr: f32,
|
lhr: f32,
|
||||||
|
@ -63,17 +63,18 @@ pub(crate) fn calcul_donated_time(
|
||||||
output_console(gui_api_xvb, &msg_lhr);
|
output_console(gui_api_xvb, &msg_lhr);
|
||||||
output_console(gui_api_xvb, &msg_mhr);
|
output_console(gui_api_xvb, &msg_mhr);
|
||||||
output_console(gui_api_xvb, &msg_ehr);
|
output_console(gui_api_xvb, &msg_ehr);
|
||||||
// calculate how much time can be spared
|
|
||||||
|
|
||||||
|
let xvb_chr = lock!(gui_api_xvb).stats_priv.donor_1hr_avg * 1000.0;
|
||||||
|
info!("current HR on XvB (last hour): {xvb_chr}");
|
||||||
|
let shr = calc_last_hour_avg_hash_rate(&lock!(gui_api_xvb).xvb_sent_last_hour_samples);
|
||||||
|
|
||||||
|
// calculate how much time can be spared
|
||||||
let mode = lock!(gui_api_xvb).stats_priv.runtime_mode.clone();
|
let mode = lock!(gui_api_xvb).stats_priv.runtime_mode.clone();
|
||||||
|
|
||||||
let default_spared_time = time_that_could_be_spared(lhr, min_hr);
|
let default_spared_time = time_that_could_be_spared(lhr, min_hr);
|
||||||
let spared_time = match mode {
|
let spared_time = match mode {
|
||||||
RuntimeMode::Auto => {
|
RuntimeMode::Auto => {
|
||||||
info!("RuntimeMode::Auto - calculating spared_time");
|
info!("RuntimeMode::Auto - calculating spared_time");
|
||||||
let xvb_chr = lock!(gui_api_xvb).stats_priv.donor_1hr_avg * 1000.0;
|
|
||||||
info!("current HR on XvB (last hour): {xvb_chr}");
|
|
||||||
let shr = calc_last_hour_avg_hash_rate(&lock!(gui_api_xvb).xvb_sent_last_hour_samples);
|
|
||||||
// calculate how much time needed to be spared to be in most round type minimum HR + buffer
|
// calculate how much time needed to be spared to be in most round type minimum HR + buffer
|
||||||
minimum_time_for_highest_accessible_round(default_spared_time, lhr, xvb_chr, shr)
|
minimum_time_for_highest_accessible_round(default_spared_time, lhr, xvb_chr, shr)
|
||||||
},
|
},
|
||||||
|
@ -95,7 +96,9 @@ pub(crate) fn calcul_donated_time(
|
||||||
XVB_TIME_ALGO - (XVB_TIME_ALGO * (keep_hr as u32) / (lhr as u32))
|
XVB_TIME_ALGO - (XVB_TIME_ALGO * (keep_hr as u32) / (lhr as u32))
|
||||||
},
|
},
|
||||||
RuntimeMode::ManualDonationLevel => {
|
RuntimeMode::ManualDonationLevel => {
|
||||||
todo!()
|
let donation_level = lock!(gui_api_xvb).stats_priv.runtime_manual_donation_level.clone();
|
||||||
|
|
||||||
|
minimum_time_for_manual_round(donation_level, default_spared_time, lhr, xvb_chr, shr)
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -198,6 +201,35 @@ fn minimum_time_for_highest_accessible_round(st: u32, lhr: f32, chr: f32, shr: f
|
||||||
|
|
||||||
(((hr_for_xvb - (hr_for_xvb - min)) / lhr) * XVB_TIME_ALGO as f32).ceil() as u32
|
(((hr_for_xvb - (hr_for_xvb - min)) / lhr) * XVB_TIME_ALGO as f32).ceil() as u32
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn minimum_time_for_manual_round(level: RuntimeDonationLevel, st: u32, lhr: f32, chr: f32, shr: f32) -> u32 {
|
||||||
|
let hr_for_xvb = ((st - 1) as f32 / XVB_TIME_ALGO as f32) * lhr;
|
||||||
|
info!(
|
||||||
|
"hr for xvb is: ({st} / {}) * {lhr} = {hr_for_xvb}H/s",
|
||||||
|
XVB_TIME_ALGO
|
||||||
|
);
|
||||||
|
let ohr = chr - shr;
|
||||||
|
|
||||||
|
let min = match level {
|
||||||
|
RuntimeDonationLevel::Donor => {
|
||||||
|
XVB_ROUND_DONOR_MIN_HR as f32 - ohr
|
||||||
|
},
|
||||||
|
RuntimeDonationLevel::DonorVIP => {
|
||||||
|
XVB_ROUND_DONOR_VIP_MIN_HR as f32 - ohr
|
||||||
|
},
|
||||||
|
RuntimeDonationLevel::DonorWhale => {
|
||||||
|
XVB_ROUND_DONOR_WHALE_MIN_HR as f32 - ohr
|
||||||
|
},
|
||||||
|
RuntimeDonationLevel::DonorMega => {
|
||||||
|
XVB_ROUND_DONOR_MEGA_MIN_HR as f32 - ohr
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(((hr_for_xvb - (hr_for_xvb - min)) / lhr) * XVB_TIME_ALGO as f32).ceil() as u32
|
||||||
|
}
|
||||||
|
|
||||||
#[allow(clippy::too_many_arguments)]
|
#[allow(clippy::too_many_arguments)]
|
||||||
async fn sleep_then_update_node_xmrig(
|
async fn sleep_then_update_node_xmrig(
|
||||||
spared_time: u32,
|
spared_time: u32,
|
||||||
|
|
|
@ -29,7 +29,6 @@ pub enum RuntimeMode {
|
||||||
|
|
||||||
#[derive(Debug, Clone, Deserialize, PartialEq, Eq)]
|
#[derive(Debug, Clone, Deserialize, PartialEq, Eq)]
|
||||||
pub enum RuntimeDonationLevel {
|
pub enum RuntimeDonationLevel {
|
||||||
VIP,
|
|
||||||
Donor,
|
Donor,
|
||||||
DonorVIP,
|
DonorVIP,
|
||||||
DonorWhale,
|
DonorWhale,
|
||||||
|
@ -145,7 +144,6 @@ impl From<XvbMode> for RuntimeMode {
|
||||||
impl From<ManualDonationLevel> for RuntimeDonationLevel {
|
impl From<ManualDonationLevel> for RuntimeDonationLevel {
|
||||||
fn from(level: ManualDonationLevel) -> Self {
|
fn from(level: ManualDonationLevel) -> Self {
|
||||||
match level {
|
match level {
|
||||||
ManualDonationLevel::VIP => RuntimeDonationLevel::VIP,
|
|
||||||
ManualDonationLevel::Donor => RuntimeDonationLevel::Donor,
|
ManualDonationLevel::Donor => RuntimeDonationLevel::Donor,
|
||||||
ManualDonationLevel::DonorVIP => RuntimeDonationLevel::DonorVIP,
|
ManualDonationLevel::DonorVIP => RuntimeDonationLevel::DonorVIP,
|
||||||
ManualDonationLevel::DonorWhale => RuntimeDonationLevel::DonorWhale,
|
ManualDonationLevel::DonorWhale => RuntimeDonationLevel::DonorWhale,
|
||||||
|
@ -162,6 +160,6 @@ impl Default for RuntimeMode {
|
||||||
|
|
||||||
impl Default for RuntimeDonationLevel {
|
impl Default for RuntimeDonationLevel {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self::VIP
|
Self::Donor
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue