infinilm_model.hpp 526 Bytes
Newer Older
1
2
3
4
#pragma once

#include "infinicore/nn/module.hpp"

5
6
#include "../cache/cache.hpp"

7
8
9
10
11
12
13
#include <any>

namespace infinilm {
class InfinilmModel : public infinicore::nn::Module {
public:
    virtual ~InfinilmModel() = default;
    virtual infinicore::Tensor forward(std::vector<std::any>) const = 0;
Ceng's avatar
Ceng committed
14
15
    // Optional: reset cache; default no-op for models without cache
    virtual void reset_cache(size_t pos = 0) {}
16
    virtual void reset_cache(const cache::CacheConfig &new_config, size_t pos = 0) = 0;
17
18
};
} // namespace infinilm