Skip to content
Snippets Groups Projects
CacheMan.cpp 4.17 KiB
Newer Older
Ruonan Wang's avatar
Ruonan Wang committed
/*
 * Distributed under the OSI-approved Apache License, Version 2.0.  See
 * accompanying file Copyright.txt for details.
 *
 * CacheMan.cpp
 *
 *  Created on: Apr 18, 2017
 *      Author: Jason Wang
 */

#include "CacheMan.h"

#include <algorithm>
#include <limits>

int CacheItem::init(json p_jmsg)
{
Ruonan Wang's avatar
Ruonan Wang committed
    m_doid = p_jmsg["doid"].get<std::string>();
    m_var = p_jmsg["var"].get<std::string>();
    m_dtype = p_jmsg["dtype"].get<std::string>();
Ruonan Wang's avatar
Ruonan Wang committed
    m_varshape = p_jmsg["varshape"].get<std::vector<size_t>>();
Ruonan Wang's avatar
Ruonan Wang committed
    m_dsize = p_jmsg["dsize"].get<size_t>();
    m_varsize = p_jmsg["varsize"].get<size_t>();
    m_varbytes = p_jmsg["varbytes"].get<size_t>();
Ruonan Wang's avatar
Ruonan Wang committed

    if (m_buffer[m_timestep].size() != m_varbytes)
    {
        m_buffer[m_timestep].resize(m_varbytes);
    }
    return 0;
}

int CacheItem::put(const void *p_data, json p_jmsg)
{
    init(p_jmsg);
    std::vector<size_t> p_putshape =
        p_jmsg["putshape"].get<std::vector<size_t>>();
    std::vector<size_t> p_varshape =
        p_jmsg["varshape"].get<std::vector<size_t>>();
    std::vector<size_t> p_offset = p_jmsg["offset"].get<std::vector<size_t>>();

Ruonan Wang's avatar
Ruonan Wang committed
    size_t putsize = p_jmsg["putsize"].get<size_t>();
Ruonan Wang's avatar
Ruonan Wang committed
    size_t chunksize = p_putshape.back();
    for (size_t i = 0; i < putsize; i += chunksize)
    {
        std::vector<size_t> p = one2multi(p_putshape, i);
        p = apply_offset(p, p_offset);
        size_t ig = multi2one(p_varshape, p);
Ruonan Wang's avatar
Ruonan Wang committed
        std::copy((char *)p_data + i * m_dsize,
                  (char *)p_data + i * m_dsize + chunksize * m_dsize,
                  m_buffer[m_timestep].data() + ig * m_dsize);
Ruonan Wang's avatar
Ruonan Wang committed
    }

    return 0;
}

std::vector<size_t> CacheItem::get_shape() { return m_varshape; }

std::string CacheItem::get_dtype() { return m_dtype; }

void CacheItem::flush() { m_timestep++; }

void CacheMan::remove(std::string doid, std::string var, size_t timestep)
{
    m_cache[doid][var].remove(timestep);
}

void CacheMan::remove_all(size_t timestep)
{
    for (auto i : m_cache)
    {
        for (auto j : m_cache[i.first])
        {
            j.second.remove(timestep);
        }
    }
}

void CacheItem::remove(size_t timestep) { m_buffer.erase(timestep); }

void CacheItem::clean(const std::string mode)
{
    if (mode == "zero")
    {
        std::memset(m_buffer[m_timestep].data(), 0, m_varbytes);
        return;
    }
    if (mode == "nan")
    {
        for (size_t i = 0; i < m_varsize; i++)
        {
            if (m_dtype == "float")
                ((float *)m_buffer[m_timestep].data())[i] =
                    std::numeric_limits<float>::quiet_NaN();
        }
        return;
    }
}

const void *CacheItem::get_buffer() { return m_buffer[m_timestep].data(); }

int CacheMan::put(const void *p_data, json p_jmsg)
{
Ruonan Wang's avatar
Ruonan Wang committed
    std::string doid = p_jmsg["doid"].get<std::string>();
    std::string var = p_jmsg["var"].get<std::string>();
    return m_cache[doid][var].put(p_data, p_jmsg);
Ruonan Wang's avatar
Ruonan Wang committed
}

void CacheMan::flush()
{
    for (auto i : m_cache)
    {
        for (auto j : m_cache[i.first])
        {
            j.second.flush();
        }
    }
}

const void *CacheMan::get_buffer(std::string doid, std::string var)
{
    return m_cache[doid][var].get_buffer();
}

void CacheMan::clean(std::string doid, std::string var, std::string mode)
{
    m_cache[doid][var].clean(mode);
}

void CacheMan::clean_all(std::string mode)
{
    for (auto i = m_cache.begin(); i != m_cache.end(); ++i)
    {
        for (auto j = m_cache[i->first].begin(); j != m_cache[i->first].end();
             ++j)
        {
            j->second.clean(mode);
        }
    }
}

std::vector<std::string> CacheMan::get_do_list()
{
    std::vector<std::string> do_list;
    for (auto it = m_cache.begin(); it != m_cache.end(); ++it)
        do_list.push_back(it->first);
    return do_list;
}

std::vector<std::string> CacheMan::get_var_list(std::string doid)
{
    std::vector<std::string> var_list;
    for (auto it = m_cache[doid].begin(); it != m_cache[doid].end(); ++it)
        var_list.push_back(it->first);
    return var_list;
}

std::vector<size_t> CacheMan::get_shape(std::string doid, std::string var)
{
    return m_cache[doid][var].get_shape();
}

std::string CacheMan::get_dtype(std::string doid, std::string var)
{
    return m_cache[doid][var].get_dtype();
}