diff --git a/checkin_notes b/checkin_notes index a1134b535b..eeaf354918 100644 --- a/checkin_notes +++ b/checkin_notes @@ -8889,3 +8889,14 @@ Rom 4 Nov 2009 client cs_platforms.cpp + +David 4 Nov 2009 + - test code for new credit system + + db/ + boinc_db.h + lib/ + average.h + sched/ + Makefile.am + credit_test.cpp diff --git a/db/boinc_db.h b/db/boinc_db.h index c81f70f9ba..b9f8942dba 100644 --- a/db/boinc_db.h +++ b/db/boinc_db.h @@ -29,6 +29,7 @@ #include #include "db_base.h" +#include "average.h" extern DB_CONN boinc_db; @@ -75,6 +76,7 @@ struct APP { // should come from this app bool beta; int target_nresults; + AVERAGE vnpfc; int write(FILE*); void clear(); @@ -115,6 +117,8 @@ struct APP_VERSION { // the following used by scheduler, not in DB // BEST_APP_VERSION* bavp; + AVERAGE pfc; + double pfc_scale_factor; int write(FILE*); void clear(); @@ -506,6 +510,7 @@ struct RESULT { int parse_from_client(FILE*); char platform_name[256]; BEST_APP_VERSION* bavp; + void clear(); int write_to_client(FILE*); }; diff --git a/doc/projects.inc b/doc/projects.inc index d1a0028c31..d748147916 100644 --- a/doc/projects.inc +++ b/doc/projects.inc @@ -187,6 +187,14 @@ $astro_phys_chem = array( $mixed = array( "Multiple applications", array( + array( + "EDGeS@Home", + "http://home.edges-grid.eu/home/", + "MTA-SZTAKI Laboratory of Parallel and Distributed Systems (Budapest)", + "Scientific research in multiple areas", + "The EDGeS@Home Beta project integrates volunteer computing into the service grid network of Europe by allowing service grids to send workunits to be processed by the volunteers of this project. The scientific projects covered by the project include math, physics, biology, etc.", + "logo_edges.png" + ), array( "Ibercivis", "http://registro.ibercivis.es/", diff --git a/lib/average.h b/lib/average.h new file mode 100644 index 0000000000..d8080cbb9d --- /dev/null +++ b/lib/average.h @@ -0,0 +1,58 @@ +// structure for tracking the recent mean and variance +// of a distribution that may change over time +// +// We maintain the mean/var in two ways: +// 1) over the entire history of samples, using the algorithm from +// http://en.wikipedia.org/wiki/Algorithms_for_calculating_variance +// 2) as an exponentially-smoothed recent average +// +// When the number of samples is small we use 1). +// Then we switch to 2). + +#define MIN_SAMPLES 50 + // after this many samples, use exponential average +#define SAMPLE_WEIGHT 0.005 + // new samples get this weight in exp avg +#define SAMPLE_LIMIT 10 + // cap samples at recent_mean*10 + +struct AVERAGE { + int n; + double mean; + double sum_var; + // sample variance is this divided by (n-1) + double recent_mean; + double recent_var; + + void update(double sample) { + if (sample < 0) return; + if (n > MIN_SAMPLES) { + if (sample > recent_mean*SAMPLE_LIMIT) { + sample = recent_mean*SAMPLE_LIMIT; + } + } + n++; + double delta = sample - mean; + mean += delta/n; + sum_var += delta*(sample-mean); + + if (n < MIN_SAMPLES) { + recent_mean = mean; + recent_var = sum_var/n; + } else { + // update recent averages + delta = sample - recent_mean; + recent_mean += SAMPLE_WEIGHT*delta; + double d2 = delta*delta - recent_var; + recent_var += SAMPLE_WEIGHT*d2; + } + } + + void clear() { + n = 0; + mean = 0; + sum_var = 0; + recent_mean = 0; + recent_var = 0; + } +}; diff --git a/sched/Makefile.am b/sched/Makefile.am index e516d3d378..da5f6b88bd 100644 --- a/sched/Makefile.am +++ b/sched/Makefile.am @@ -98,6 +98,7 @@ bin_PROGRAMS = \ sched_PROGRAMS = \ census \ + credit_test \ db_dump \ db_purge \ feeder \ @@ -163,6 +164,10 @@ census_SOURCES = \ hr_info.cpp census_LDADD = $(SERVERLIBS) +credit_test_SOURCES = \ + credit_test.cpp +credit_test_LDADD = $(SERVERLIBS) + feeder_SOURCES = \ feeder.cpp \ hr.cpp \ diff --git a/sched/credit_test.cpp b/sched/credit_test.cpp new file mode 100644 index 0000000000..d4eb4d6b8a --- /dev/null +++ b/sched/credit_test.cpp @@ -0,0 +1,163 @@ +#include +#include "sched_config.h" +#include "boinc_db.h" + +struct HOST_APP { + int host_id; + int app_id; + AVERAGE vnpfc; +}; + +struct HOST_APP_VERSION { + int host_id; + int app_version_id; + AVERAGE et; +}; + +vector app_versions; +vector apps; +vector host_apps; +vector host_app_versions; + +// update app version scale factors +// +void update_av_scales() { + unsigned int i, j; + for (i=0; i