Skip to content

Commit

Permalink
3582: Add a forecast model giving the median over the last N phases
Browse files Browse the repository at this point in the history
  • Loading branch information
PhilMiller committed Jul 21, 2020
1 parent 0f892a6 commit b7241e8
Show file tree
Hide file tree
Showing 2 changed files with 161 additions and 0 deletions.
80 changes: 80 additions & 0 deletions src/vt/vrt/collection/balance/model/persistence_median_last_n.cc
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
/*
//@HEADER
// *****************************************************************************
//
// persistence_median_last_n.cc
// DARMA Toolkit v. 1.0.0
// DARMA/vt => Virtual Transport
//
// Copyright 2019 National Technology & Engineering Solutions of Sandia, LLC
// (NTESS). Under the terms of Contract DE-NA0003525 with NTESS, the U.S.
// Government retains certain rights in this software.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// * Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// * Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
//
// * Neither the name of the copyright holder nor the names of its
// contributors may be used to endorse or promote products derived from this
// software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
//
// Questions? Contact [email protected]
//
// *****************************************************************************
//@HEADER
*/

#include "vt/config.h"
#include "vt/vrt/collection/balance/model/persistence_median_last_n.h"
#include <utility>

namespace vt { namespace vrt { namespace collection { namespace balance {

PersistenceMedianLastN::PersistenceMedianLastN(std::shared_ptr<LoadModel> base, int n)
: ComposedModel(base)
, n_(n)
{
vtAssert(n > 0, "Cannot take a median over no phases");
}

TimeType PersistenceMedianLastN::getWork(ElementIDType object, PhaseOffset when)
{
// Retrospective queries don't call for a prospective calculation
if (when.phases < 0)
return ComposedModel::getWork(object, when);

int phases = std::min(n_, completed_phases_);
std::vector<TimeType> times(phases);
for (int i = 1; i <= phases; ++i) {
PhaseOffset p{-1*i, when.subphase};
TimeType t = ComposedModel::getWork(object, p);
times[i-1] = t;
}

std::sort(times.begin(), times.end());

if (phases % 2 == 1)
return times[phases / 2 + 1];
else
return (times[phases / 2] + times[phases / 2 + 1]) / 2;
}

}}}}
81 changes: 81 additions & 0 deletions src/vt/vrt/collection/balance/model/persistence_median_last_n.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
/*
//@HEADER
// *****************************************************************************
//
// persistence_median_last_n.h
// DARMA Toolkit v. 1.0.0
// DARMA/vt => Virtual Transport
//
// Copyright 2019 National Technology & Engineering Solutions of Sandia, LLC
// (NTESS). Under the terms of Contract DE-NA0003525 with NTESS, the U.S.
// Government retains certain rights in this software.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// * Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// * Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
//
// * Neither the name of the copyright holder nor the names of its
// contributors may be used to endorse or promote products derived from this
// software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
//
// Questions? Contact [email protected]
//
// *****************************************************************************
//@HEADER
*/

#if !defined INCLUDED_VRT_COLLECTION_BALANCE_PERSISTENCE_MEDIAN_LAST_N_H
#define INCLUDED_VRT_COLLECTION_BALANCE_PERSISTENCE_MEDIAN_LAST_N_H

#include "vt/config.h"
#include "vt/vrt/collection/balance/model/composed_model.h"
#include <unordered_map>

namespace vt { namespace vrt { namespace collection { namespace balance {

/**
* \brief Predicts loads as the median of the last N phases
*
* This may be useful as a rudimentary form of noise filtering, or in
* general where a single phase worth of timings might not be ideally
* representative
*/
struct PersistenceMedianLastN : public ComposedModel
{
/**
* \param[in] base The underlying model
* \param[in] n the number of preceding phases to use in making a prediction
*/
PersistenceMedianLastN(std::shared_ptr<LoadModel> base, int n);

void updateLoads(PhaseType last_completed_phase) override
{ completed_phases_ = last_completed_phase; }

TimeType getWork(ElementIDType object, PhaseOffset when) override;

private:
int n_;
int completed_phases_;
}; // class PersistenceMedianLastN

}}}} // namespaces

#endif

0 comments on commit b7241e8

Please sign in to comment.