Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Stats managers #63

Merged
merged 53 commits into from
Jun 1, 2016
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
2164781
Last commit before I completely overhaul OEE.h
emilydolson Apr 6, 2016
eba2749
Merge branch 'master' of github.com:devosoft/Empirical
emilydolson Apr 8, 2016
d70eea3
Merge branch 'master' of github.com:devosoft/Empirical
emilydolson Apr 19, 2016
4e615bc
Adding update signal
emilydolson Apr 22, 2016
24aa95f
Merge branch 'master' of github.com:devosoft/Empirical
emilydolson Apr 22, 2016
0ebbf5c
Complexity and Ecology work
emilydolson May 11, 2016
b787d67
Fixed merge conflict
emilydolson May 11, 2016
2c7be2f
Merge branch 'master' of github.com:devosoft/Empirical
emilydolson May 11, 2016
6ae3880
All metrics work
emilydolson May 11, 2016
2abc7e5
All metrics work
emilydolson May 12, 2016
fdd1819
All metrics work, skeletonization streamlined
emilydolson May 13, 2016
570aab4
Separate generations deduction works now
emilydolson May 13, 2016
e718cf2
Merge branch 'master' of github.com:devosoft/Empirical
emilydolson May 13, 2016
24e903a
Cleaned up OEE.h, added comments
emilydolson May 13, 2016
de8731e
Added example for OEE tracker
emilydolson May 14, 2016
7481633
Fixed bug in change deque length, added fitness tracking
emilydolson May 14, 2016
bcb6fa9
Merge branch 'master' of github.com:devosoft/Empirical
emilydolson May 14, 2016
86fe09b
Added print statement to verify settings
emilydolson May 14, 2016
88b491e
Added template specializations to appease std::vector
emilydolson May 15, 2016
8aac649
Made template specialization of ShannonDiversity to take a World
emilydolson May 18, 2016
1c525dc
Worlds are iterable
emilydolson May 18, 2016
7c51aeb
Fixing merge conflict
emilydolson May 18, 2016
779a6f4
Use world iterator in stats
emilydolson May 19, 2016
89150a8
Merge branch 'master' of github.com:devosoft/Empirical into nullorgs
emilydolson May 19, 2016
e6629c8
Fixed tournament selection to only choose from valid orgs
emilydolson May 19, 2016
229d7d9
NK_OEE now uses const landscapes
emilydolson May 19, 2016
39d792d
Lineage tracker does everything automatically with signals
emilydolson May 19, 2016
b119b08
Made ids actually propagate correctly
emilydolson May 19, 2016
295fd66
Elite selection is null org safe
emilydolson May 19, 2016
7795f83
GetValidOrgIndices actually works now
emilydolson May 19, 2016
0303f20
Merge in Jake and Stevens addition to Stats.h
emilydolson May 20, 2016
c41f784
Merge in null org handling
emilydolson May 20, 2016
a740eb6
Base stats manager functionality works
emilydolson May 20, 2016
f331839
StatsManagers handle output locations
emilydolson May 22, 2016
b718da7
Worlditerator uses pointers
emilydolson May 22, 2016
a848858
Added error message for invalid file
emilydolson May 22, 2016
b68dba6
Created default stats manager, made header
emilydolson May 23, 2016
14a5af0
Merge branch 'master' of github.com:devosoft/Empirical
emilydolson May 23, 2016
261a9f3
Added comments, cleaned up types
emilydolson May 23, 2016
49744de
OEE stats manager uses base output
emilydolson May 23, 2016
09fdf57
Stats managers have config files
emilydolson May 23, 2016
34198f6
Fixed possible null dereference in tournament fitness calculation
emilydolson May 23, 2016
db2c17d
Guard against null dereference in MutatePop
emilydolson May 23, 2016
39ae05f
StatsManagers can be passed as template arguments
emilydolson May 27, 2016
eb645f2
LineageTracker and OEEStats now follow general StatsManager format
emilydolson May 29, 2016
2149343
LineageTracker and OEEStats now follow general StatsManager format
emilydolson May 29, 2016
4fd1544
Merge branch 'master' of github.com:emilydolson/Empirical
emilydolson May 29, 2016
0a6b803
Lineage tracker automatically hooks up to OEE stats
emilydolson May 29, 2016
97f0ffb
Automatic lineage tracker construction works
emilydolson May 29, 2016
adadaac
Made stats generic and moved them to tools
emilydolson May 29, 2016
a92e954
Merge branch 'master' of github.com:devosoft/Empirical
emilydolson May 30, 2016
a80244f
Fixed g++ compilation bug
emilydolson May 31, 2016
a6897a1
Stats Manager headers + assorted cleanup
emilydolson Jun 1, 2016
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Automatic lineage tracker construction works
  • Loading branch information
emilydolson committed May 29, 2016
commit 97f0ffb3aa88dd6affb5bb3636402ca2e4a0fd3c
6 changes: 5 additions & 1 deletion evo/LineageTracker.h
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@
#include <map>
#include <set>
#include "../tools/vector.h"
#include "World.h"
#include "PopulationManager.h"

namespace emp{
Expand All @@ -19,6 +18,9 @@ namespace evo{
public:
static constexpr bool emp_is_lineage_manager = true;
LineageTracker_Null(){;};

template <typename WORLD>
void Setup(WORLD * w){;}
};

// Class to keep track of lineages
Expand Down Expand Up @@ -169,6 +171,8 @@ namespace evo{

};

using LineageNull = LineageTracker_Null<PopBasic>;
using LineageStandard = LineageTracker<PopBasic>;

}
}
Expand Down
14 changes: 8 additions & 6 deletions evo/OEE.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,8 @@
#include "../tools/vector.h"
#include "../tools/array.h"
#include "LineageTracker.h"
#include "World.h"
#include "PopulationManager.h"
#include "Stats.h"
#include "StatsManager.h"
#include "OEE.h"

namespace emp{
namespace evo{
Expand All @@ -35,9 +32,11 @@ namespace evo{
//Is there a way to avoid making this global but still do inheritance right?
OEEStatsManagerConfig OeeConfig;

template <typename POP_MANAGER, int MAX_ORG_SIZE = OeeConfig.ORG_LENGTH()>
template <typename POP_MANAGER>
class OEEStatsManager : StatsManager_Base<POP_MANAGER> {
private:
//This prevents compilation under g++
static constexpr int MAX_ORG_SIZE = OeeConfig.ORG_LENGTH();
using org_ptr = typename POP_MANAGER::value_type;
using ORG = typename std::remove_pointer<org_ptr>::type;
using skeleton_type = emp::array<int, MAX_ORG_SIZE>;
Expand All @@ -57,7 +56,8 @@ namespace evo{

public:
using StatsManager_Base<POP_MANAGER>::emp_is_stats_manager;
LineageTracker<POP_MANAGER> * lineage;
using lineage_type = LineageTracker<POP_MANAGER>;
lineage_type * lineage;
std::function<double(org_ptr)> fit_fun;

template <typename WORLD>
Expand All @@ -68,7 +68,8 @@ namespace evo{
Setup(w);
}

OEEStatsManager(){;}
OEEStatsManager(std::string location = "oee_stats.csv")
: StatsManager_Base<POP_MANAGER>(OeeConfig, "OEE_stats.cfg", location){;}

template <typename WORLD>
void Setup(WORLD * w) {
Expand Down Expand Up @@ -393,6 +394,7 @@ namespace evo{
}


using OEEStats = OEEStatsManager<PopBasic>;
}
}

Expand Down
3 changes: 0 additions & 3 deletions evo/PopulationIterator.h
Original file line number Diff line number Diff line change
@@ -1,9 +1,6 @@
#ifndef EMP_EVO_POP_ITER_H
#define EMP_EVO_POP_ITER_H

//#include "World.h"
#include "PopulationManager.h"

namespace emp{
namespace evo{

Expand Down
3 changes: 2 additions & 1 deletion evo/Stats.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,9 @@
#include <cmath>
#include <vector>
#include <set>
#include <functional>

#include "../tools/vector.h"
#include "World.h"

namespace emp{
namespace evo{
Expand Down
3 changes: 2 additions & 1 deletion evo/StatsManager.h
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@

#include "../tools/FunctionSet.h"
#include "../tools/vector.h"
#include "World.h"
#include "Stats.h"
#include "../config/config.h"
#include "PopulationManager.h"
Expand Down Expand Up @@ -228,6 +227,8 @@ namespace evo{

};

using NullStats = StatsManager_Base<PopBasic>;
using DefaultStats = StatsManager_DefaultStats<PopBasic>;
}
}

Expand Down
14 changes: 10 additions & 4 deletions evo/World.h
Original file line number Diff line number Diff line change
Expand Up @@ -91,12 +91,13 @@
#include "../tools/reflection.h"
#include "../tools/vector.h"


#include "OrgSignals.h"
#include "OrgManager.h"
#include "PopulationManager.h"
#include "StatsManager.h"
#include "LineageTracker.h"
#include "OEE.h"


// Macro to add class elements associated with a dynamic function call.
// For example, if you wanted to be able to have a dynamic fitness function, you would call:
Expand Down Expand Up @@ -130,10 +131,12 @@ template <typename... T> void FUN(T &&... args) { \
namespace emp {
namespace evo {


EMP_SETUP_TYPE_SELECTOR(SelectPopManager, emp_is_population_manager);
EMP_SETUP_TYPE_SELECTOR(SelectOrgManager, emp_is_organism_manager);
EMP_SETUP_TYPE_SELECTOR(SelectStatsManager, emp_is_stats_manager);
EMP_SETUP_TYPE_SELECTOR(SelectLineageManager, emp_is_lineage_manager);
EMP_SETUP_TYPE_SELECTOR(NeedsLineageManager, lineage);

template <typename POP_MANAGER> class PopulationIterator;

Expand All @@ -144,10 +147,13 @@ namespace evo {
// Build managers...
AdaptTemplate<typename SelectPopManager<MANAGERS...,PopBasic>::type, ORG> popM;
AdaptTemplate<typename SelectOrgManager<MANAGERS...,OrgMDynamic>::type, ORG> orgM;
//AdaptTemplate<typename SelectStatsManager<MANAGERS...,StatsManager_Base<decltype(popM)> >::type, decltype(popM)> statsM;
AdaptTemplate<typename SelectLineageManager<MANAGERS..., LineageTracker<PopBasic> >::type, decltype(popM)> lineageM;
AdaptTemplate<typename SelectStatsManager<MANAGERS...,StatsManager_Base<decltype(popM)> >::type, decltype(popM)> statsM;

//Create a lineage manager if the stats manager needs it or if the user asked for it
EMP_CHOOSE_MEMBER_TYPE(DefaultLineage, lineage_type, LineageNull, decltype(statsM));
AdaptTemplate<typename SelectLineageManager<MANAGERS...,DefaultLineage>::type, decltype(popM)> lineageM;

OEEStatsManager<decltype(popM), 20> statsM;
//emp::evo::OEEStatsManager<decltype(popM)> statsM;

Random * random_ptr;
bool random_owner;
Expand Down
11 changes: 3 additions & 8 deletions examples/evo/NK_OEE.cc
Original file line number Diff line number Diff line change
Expand Up @@ -14,11 +14,11 @@
#include <functional>

#include "../../evo/NK-const.h"
#include "../../evo/World.h"
#include "../../evo/OEE.h"
#include "../../evo/World.h"
#include "../../tools/BitSet.h"
#include "../../tools/Random.h"
#include "../../evo/Stats.h"
#include "../../evo/StatsManager.h"


constexpr int K = 3;
Expand All @@ -35,12 +35,7 @@ int main()
std::cout << "N: " << N << ", K: " << K << ", POP_SIZE: " << POP_SIZE << ", Selection: " << "Standard_tournament" << ", TournamentSize: " << TOURNAMENT_SIZE << std::endl;
emp::Random random;
emp::evo::NKLandscapeConst<N,K> landscape(random);
emp::evo::World<BitOrg, emp::evo::StatsManager_DefaultStats<emp::evo::PopulationManager_Base<BitOrg> > > pop(random);
//emp::evo::OEEStatsManager<BitOrg, N> oee_stats(&pop, "cout");
//emp::evo::LineageTracker<BitOrg> lin(&pop);
//oee_stats.lineage = &lin;

//emp::evo::StatsManager_DefaultStats<BitOrg> common_stats(&pop, "cout");
emp::evo::World<BitOrg, emp::evo::OEEStats > pop(random);

//#ifdef EMSCRIPTEN
//std::cout << n_objects() << std::endl;
Expand Down