diff options
| author | Jaron Kent-Dobias <jaron@kent-dobias.com> | 2019-09-04 08:19:26 -0400 | 
|---|---|---|
| committer | Jaron Kent-Dobias <jaron@kent-dobias.com> | 2019-09-04 08:19:26 -0400 | 
| commit | f18103d3ef037ab00004ef2095162b3802af58c2 (patch) | |
| tree | a83da994ad996e007561127cab09bb1fdf2bf37c /src | |
| parent | d4e6135a179cf6005cc50800f060854b34ae2e8b (diff) | |
| parent | db745a57fc981df7db3c308321d4023d75adf351 (diff) | |
| download | fuse_networks-f18103d3ef037ab00004ef2095162b3802af58c2.tar.gz fuse_networks-f18103d3ef037ab00004ef2095162b3802af58c2.tar.bz2 fuse_networks-f18103d3ef037ab00004ef2095162b3802af58c2.zip | |
Merge branch 'elastic' of git:research/fracture/code into elastic
Diffstat (limited to 'src')
| -rw-r--r-- | src/animate.cpp | 3 | ||||
| -rw-r--r-- | src/animate.hpp | 1 | ||||
| -rw-r--r-- | src/measurements.cpp | 72 | ||||
| -rw-r--r-- | src/measurements.hpp | 11 | ||||
| -rw-r--r-- | src/percolation.cpp | 4 | 
5 files changed, 71 insertions, 20 deletions
| diff --git a/src/animate.cpp b/src/animate.cpp index b1031dc..a7b6173 100644 --- a/src/animate.cpp +++ b/src/animate.cpp @@ -17,6 +17,7 @@ void animate::pre_fracture(const network &n) {    lv = std::numeric_limits<long double>::lowest();    avalanches = {};    boost::remove_edge_if(trivial, G); +  seen_guy = false;    glClearColor(1.0f, 1.0f, 1.0f, 1.0f );    glLineWidth(5); @@ -135,7 +136,7 @@ void animate::bond_broken(const network& n, const current_info& cur, unsigned i)        }   glEnd();   glFlush(); - if (nw > 2) {std::cout << "\n"; getchar();} + if (nw > 2 && !seen_guy) {seen_guy = true; getchar();}  }  void animate::post_fracture(network &n) { diff --git a/src/animate.hpp b/src/animate.hpp index fcb89fc..865b3bd 100644 --- a/src/animate.hpp +++ b/src/animate.hpp @@ -10,6 +10,7 @@  class animate : public hooks {    private:      Graph G; +    bool seen_guy;    public:      long double lv;      std::list<std::list<unsigned>> avalanches; diff --git a/src/measurements.cpp b/src/measurements.cpp index 96b4ccb..984b80c 100644 --- a/src/measurements.cpp +++ b/src/measurements.cpp @@ -38,15 +38,13 @@ void update_distribution_file(std::string id, const std::vector<uint64_t>& data,  }  template <class T> -void update_field_file(std::string id, const std::vector<T>& data, unsigned N, std::string model_string, unsigned Mx, unsigned My) { -  std::string filename = model_string + id + "_" + std::to_string(Mx) + "_" + std::to_string(My) + ".dat"; +void update_field_file(std::string id, const std::vector<T>& data, std::string model_string) { +  std::string filename = model_string + id + ".dat";    std::ifstream file(filename); -  uint64_t N_old = 0;    std::vector<T> data_old(data.size(), 0);    if (file.is_open()) { -    file >> N_old;      for (unsigned j = 0; j < data.size(); j++) {        file >> data_old[j];      } @@ -55,7 +53,6 @@ void update_field_file(std::string id, const std::vector<T>& data, unsigned N, s    std::ofstream file_out(filename); -  file_out <<std::fixed<< N_old + N <<  "\n";    for (unsigned j = 0; j < data.size(); j++) {      file_out << data_old[j] + data[j] << " ";    } @@ -92,7 +89,7 @@ void correlation(unsigned Mx, unsigned My, std::vector<std::vector<T>>& data, co    }  } -void autocorrelation2(double Lx, double Ly, unsigned Mx, unsigned My, std::vector<uint64_t>& data, const std::list<graph::coordinate>& pos) { +void autocorrelation2(double Lx, double Ly, unsigned Mx, unsigned My, std::vector<uint64_t>& data, const std::list<graph::coordinate>& pos, std::array<unsigned, 2> count) {    for (std::list<graph::coordinate>::const_iterator it1 = pos.begin(); it1 != pos.end(); it1++) {      for (std::list<graph::coordinate>::const_iterator it2 = it1; it2 != pos.end(); it2++) {        double Δx_tmp = fabs(it1->x - it2->x); @@ -101,7 +98,11 @@ void autocorrelation2(double Lx, double Ly, unsigned Mx, unsigned My, std::vecto        double Δy_tmp = fabs(it1->y - it2->y);        double Δy = Δy_tmp < Ly / 2 ? Δy_tmp : Ly - Δy_tmp; -      data[(unsigned)(Mx * (Δx / Lx)) + (Mx / 2) * (unsigned)(My * (Δy / Ly))]++; +      if (count[0] % 2 == 0) { +        data[(unsigned)(Mx * (Δx / Lx)) + (Mx / 2) * (unsigned)(My * (Δy / Ly))]++; +      } else { +        data[(unsigned)(Mx * (Δy / Ly)) + (Mx / 2) * (unsigned)(My * (Δx / Lx))]++; +      }      }    }  } @@ -153,7 +154,16 @@ ma::ma(unsigned n, double a, double beta, double weight, bool one) :    sa(3 * n),    sA(3 * n),    si(10000), -  sI(10000) +  sI(10000), +  cn(pow((unsigned)sqrt(n), 2)), +  cs(pow((unsigned)sqrt(n), 2)), +  cm(pow((unsigned)sqrt(n), 2)), +  cl(pow((unsigned)sqrt(n), 2)), +  cb(pow((unsigned)sqrt(n), 2)), +  ca(pow((unsigned)sqrt(n), 2)), +  cA(pow((unsigned)sqrt(n), 2)), +  cp(pow((unsigned)sqrt(n), 2)), +  cq(pow((unsigned)sqrt(n), 2))  {    if (beta != 0.0) {      model_string = "fracture_" + std::to_string(n) + "_" + std::to_string(a) + "_" + std::to_string(beta) + "_" + std::to_string(weight) + "_"; @@ -205,6 +215,15 @@ ma::~ma() {    update_distribution_file("sA", sA, model_string);    update_distribution_file("si", si, model_string);    update_distribution_file("sI", sI, model_string); +  update_field_file("cl", cl, model_string); +  update_field_file("cm", cm, model_string); +  update_field_file("cs", cs, model_string); +  update_field_file("cn", cn, model_string); +  update_field_file("cb", cb, model_string); +  update_field_file("ca", ca, model_string); +  update_field_file("cA", cA, model_string); +  update_field_file("cp", cp, model_string); +  update_field_file("cq", cq, model_string);  }  void ma::pre_fracture(const network&) { @@ -240,18 +259,18 @@ void ma::post_fracture(network &n) {    std::vector<unsigned> component(boost::num_vertices(G));    unsigned num = boost::connected_components(G, &component[0]);    if (post_cracks.size() > 2 || post_cracks.size() == 0) { -    for (auto c : post_cracks) { -      for (unsigned e : c.second) { -        std::cout << e << " "; -      } -      std::cout << "\n"; -    } -      getchar();      throw badcycleex;    } +    for (auto c : post_cracks) { +    std::list<graph::coordinate> cl_cs;      sl[c.second.size() - 1]++; +    for (unsigned e : c.second) { +      cl_cs.push_back(n.G.dual_edges[e].r); +    } +    autocorrelation2(n.G.L.x, n.G.L.y, 2 * sqrt(cl.size()), 2 * sqrt(cl.size()), cl, cl_cs, c.first);    } +    unsigned crack_component = component[n.G.dual_edges[post_cracks.front().second.front()].v[0]];    std::vector<std::list<graph::coordinate>> components(num); @@ -263,10 +282,14 @@ void ma::post_fracture(network &n) {    for (unsigned i = 0; i < num; i++) {      if (i != crack_component) {        sm[components[i].size() - 1]++; +      autocorrelation2(n.G.L.x, n.G.L.y, 2 * sqrt(cm.size()), 2 * sqrt(cm.size()), cm, components[i], post_cracks.front().first); +      autocorrelation2(n.G.L.x, n.G.L.y, 2 * sqrt(cp.size()), 2 * sqrt(cp.size()), cp, components[i], {0, 1});      } else {        ss[components[i].size() - 1]++; +      autocorrelation2(n.G.L.x, n.G.L.y, 2 * sqrt(cs.size()), 2 * sqrt(cs.size()), cs, components[i], post_cracks.front().first);      }      sn[components[i].size() - 1]++; +    autocorrelation2(n.G.L.x, n.G.L.y, 2 * sqrt(cn.size()), 2 * sqrt(cn.size()), cn, components[i], post_cracks.front().first);    }    std::vector<bool> vertex_in(n.G.vertices.size()); @@ -280,21 +303,38 @@ void ma::post_fracture(network &n) {    unsigned bb_size = 0; +  std::list<graph::coordinate> cb_co; +    for (unsigned i = 0; i < n.G.vertices.size(); i++) { -    if (vertex_in[i]) bb_size++; +    if (vertex_in[i]) { +      bb_size++; +      cb_co.push_back(n.G.vertices[i].r); +    }    }    sb[bb_size]++; +  autocorrelation2(n.G.L.x, n.G.L.y, 2 * sqrt(cb.size()), 2 * sqrt(cb.size()), cb, cb_co, post_cracks.front().first);    auto av_it = avalanches.rbegin();    av_it++;    while (av_it != avalanches.rend()) {      sa[(*av_it).size() - 1]++; +    std::list<graph::coordinate> ca_co; +    for (unsigned e : (*av_it)) { +      ca_co.push_back(n.G.edges[e].r); +    } +    autocorrelation2(n.G.L.x, n.G.L.y, 2 * sqrt(ca.size()), 2 * sqrt(ca.size()), ca, ca_co, post_cracks.front().first); +    autocorrelation2(n.G.L.x, n.G.L.y, 2 * sqrt(cq.size()), 2 * sqrt(cq.size()), cq, ca_co, {0,1});      av_it++;    }    sA[avalanches.back().size() - 1]++; +  std::list<graph::coordinate> cA_co; +  for (unsigned e : avalanches.back()) { +    cA_co.push_back(n.G.edges[e].r); +  } +  autocorrelation2(n.G.L.x, n.G.L.y, 2 * sqrt(cA.size()), 2 * sqrt(cA.size()), cA, cA_co, post_cracks.front().first);    sd[num - 1]++;  } diff --git a/src/measurements.hpp b/src/measurements.hpp index c211974..b22c327 100644 --- a/src/measurements.hpp +++ b/src/measurements.hpp @@ -30,13 +30,22 @@ class ma : public hooks {      std::vector<uint64_t> sl; // final avalanche size distribution      std::vector<uint64_t> sb; // final avalanche size distribution      std::vector<uint64_t> sd; // final avalanche size distribution -    std::vector<uint64_t> sc; // non-spanning cluster size distribution      std::vector<uint64_t> sa; // non-final avalanche size distribution      std::vector<uint64_t> sA; // non-final avalanche size distribution      std::vector<uint64_t> si;      std::vector<uint64_t> sI; +    std::vector<uint64_t> cn; +    std::vector<uint64_t> cs; +    std::vector<uint64_t> cm; +    std::vector<uint64_t> cl; +    std::vector<uint64_t> cb; +    std::vector<uint64_t> ca; +    std::vector<uint64_t> cA; +    std::vector<uint64_t> cp; +    std::vector<uint64_t> cq; +    public:      long double lv; diff --git a/src/percolation.cpp b/src/percolation.cpp index 0b1d0ad..b9f278e 100644 --- a/src/percolation.cpp +++ b/src/percolation.cpp @@ -81,7 +81,7 @@ int main(int argc, char* argv[]) {            graph G(n, a, rng);            percolation_network fuse_network(G, &c);            fuse_network.set_thresholds(beta, rng); -          fuse_network.fracture(meas); +          fuse_network.fracture(meas, true);            break;          } catch (std::exception &e) {            std::cout << e.what() << '\n'; @@ -99,7 +99,7 @@ int main(int argc, char* argv[]) {            graph G(Lx, Ly);            percolation_network fuse_network(G, &c);            fuse_network.set_thresholds(beta, rng); -          fuse_network.fracture(meas); +          fuse_network.fracture(meas, true);            break;          } catch (std::exception &e) {            std::cout << e.what() << '\n'; | 
