mirror of
https://github.com/Cyrix126/gupaxx.git
synced 2025-01-03 12:39:35 +00:00
fix: refactor & fix bug
This commit is contained in:
parent
6a2b6dbdd4
commit
c86dc393fa
1 changed files with 29 additions and 29 deletions
|
@ -3,7 +3,7 @@ use std::{
|
||||||
};
|
};
|
||||||
|
|
||||||
use log::{debug, info, warn};
|
use log::{debug, info, warn};
|
||||||
use readable::num::Float;
|
use readable::{num::Float, run::Runtime};
|
||||||
use reqwest::Client;
|
use reqwest::Client;
|
||||||
use tokio::time::sleep;
|
use tokio::time::sleep;
|
||||||
|
|
||||||
|
@ -24,27 +24,10 @@ pub(crate) fn calcul_donated_time(
|
||||||
gui_api_xvb: &Arc<Mutex<PubXvbApi>>,
|
gui_api_xvb: &Arc<Mutex<PubXvbApi>>,
|
||||||
state_p2pool: &crate::disk::state::P2pool,
|
state_p2pool: &crate::disk::state::P2pool,
|
||||||
) -> u32 {
|
) -> u32 {
|
||||||
|
|
||||||
let manual_amount = lock!(gui_api_xvb).stats_priv.runtime_manual_amount as u32;
|
|
||||||
let avg_hr = calc_last_hour_avg_hash_rate(&lock!(gui_api_xvb).p2pool_sent_last_hour_samples);
|
|
||||||
{
|
|
||||||
let avg_hr = avg_hr as u32;
|
|
||||||
if lock!(gui_api_xvb).stats_priv.runtime_mode == RuntimeMode::ManuallyDonante && avg_hr > 0 {
|
|
||||||
let spared_time = XVB_TIME_ALGO * manual_amount / avg_hr;
|
|
||||||
info!("spared_time = 600 * {manual_amount} / {avg_hr} = {spared_time}");
|
|
||||||
return spared_time;
|
|
||||||
}
|
|
||||||
|
|
||||||
if lock!(gui_api_xvb).stats_priv.runtime_mode == RuntimeMode::ManuallyKeep && avg_hr > 0 {
|
|
||||||
let spared_time = XVB_TIME_ALGO - (XVB_TIME_ALGO * manual_amount / avg_hr);
|
|
||||||
info!("spared_time = 600 * {manual_amount} / {avg_hr} = {spared_time}");
|
|
||||||
return spared_time;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let p2pool_ehr = lock!(gui_api_p2pool).sidechain_ehr;
|
let p2pool_ehr = lock!(gui_api_p2pool).sidechain_ehr;
|
||||||
// what if ehr stay still for the next ten minutes ? mHR will augment every ten minutes because it thinks that oHR is decreasing.
|
// what if ehr stay still for the next ten minutes ? mHR will augment every ten minutes because it thinks that oHR is decreasing.
|
||||||
//
|
//
|
||||||
|
let avg_hr = calc_last_hour_avg_hash_rate(&lock!(gui_api_xvb).p2pool_sent_last_hour_samples);
|
||||||
let mut p2pool_ohr = p2pool_ehr - avg_hr;
|
let mut p2pool_ohr = p2pool_ehr - avg_hr;
|
||||||
if p2pool_ohr < 0.0 {
|
if p2pool_ohr < 0.0 {
|
||||||
p2pool_ohr = 0.0;
|
p2pool_ohr = 0.0;
|
||||||
|
@ -77,23 +60,40 @@ pub(crate) fn calcul_donated_time(
|
||||||
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
|
// calculate how much time can be spared
|
||||||
let mut spared_time = time_that_could_be_spared(lhr, min_hr);
|
|
||||||
|
let spared_time = match lock!(gui_api_xvb).stats_priv.runtime_mode {
|
||||||
if spared_time > 0 {
|
RuntimeMode::Auto => {
|
||||||
// if not hero option
|
info!("RuntimeMode::Auto - calculating spared_time --------------------------------");
|
||||||
if lock!(gui_api_xvb).stats_priv.runtime_mode == RuntimeMode::Auto {
|
let mut spared_time = time_that_could_be_spared(lhr, min_hr);
|
||||||
let xvb_chr = lock!(gui_api_xvb).stats_priv.donor_1hr_avg * 1000.0;
|
let xvb_chr = lock!(gui_api_xvb).stats_priv.donor_1hr_avg * 1000.0;
|
||||||
info!("current HR on XvB (last hour): {xvb_chr}");
|
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);
|
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
|
||||||
spared_time = minimum_time_for_highest_accessible_round(spared_time, lhr, xvb_chr, shr);
|
spared_time = minimum_time_for_highest_accessible_round(spared_time, lhr, xvb_chr, shr);
|
||||||
|
spared_time
|
||||||
|
},
|
||||||
|
RuntimeMode::Hero => {
|
||||||
|
info!("RuntimeMode::Hero - calculating spared_time --------------------------------");
|
||||||
|
time_that_could_be_spared(lhr, min_hr)
|
||||||
|
},
|
||||||
|
RuntimeMode::ManuallyDonante => {
|
||||||
|
info!("RuntimeMode::ManuallyDonate - calculating spared_time --------------------------------");
|
||||||
|
let manual_amount = lock!(gui_api_xvb).stats_priv.runtime_manual_amount as u32;
|
||||||
|
let avg_hr = avg_hr as u32;
|
||||||
|
let spared_time = XVB_TIME_ALGO * manual_amount / avg_hr;
|
||||||
|
info!("spared_time = 600 * {manual_amount} / {avg_hr} = {spared_time}");
|
||||||
|
spared_time
|
||||||
|
},
|
||||||
|
RuntimeMode::ManuallyKeep => {
|
||||||
|
info!("RuntimeMode::ManuallyKeep - calculating spared_time --------------------------------");
|
||||||
|
let manual_amount = lock!(gui_api_xvb).stats_priv.runtime_manual_amount as u32;
|
||||||
|
let avg_hr = avg_hr as u32;
|
||||||
|
let spared_time = XVB_TIME_ALGO - (XVB_TIME_ALGO * manual_amount / avg_hr);
|
||||||
|
info!("spared_time = 600 * {manual_amount} / {avg_hr} = {spared_time}");
|
||||||
|
spared_time
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
|
||||||
}
|
|
||||||
if lock!(gui_api_xvb).stats_priv.runtime_mode == RuntimeMode::Hero {
|
|
||||||
output_console(gui_api_xvb, "Hero mode is enabled for this decision");
|
|
||||||
}
|
|
||||||
spared_time
|
spared_time
|
||||||
}
|
}
|
||||||
fn minimum_hashrate_share(difficulty: u64, mini: bool, ohr: f32) -> f32 {
|
fn minimum_hashrate_share(difficulty: u64, mini: bool, ohr: f32) -> f32 {
|
||||||
|
|
Loading…
Reference in a new issue