2023-06-06 21:09:00 +00:00
# ifndef REPLIT_H_I_KNOW_WHAT_I_AM_DOING_WHEN_INCLUDING_THIS_FILE
# error This file is NOT meant to be included outside of replit.cpp. Doing so is DANGEROUS. Be sure to know what you are doing before proceeding to #define REPLIT_H_I_KNOW_WHAT_I_AM_DOING_WHEN_INCLUDING_THIS_FILE
# endif
# ifndef REPLIT_H
# define REPLIT_H
# include <string>
# include <functional>
# include <vector>
# include "llmodel.h"
# define GGML_QNT_VERSION_FACTOR 1000 // do not change this
struct ReplitPrivate ;
class Replit : public LLModel {
public :
Replit ( ) ;
~ Replit ( ) ;
2023-07-09 15:32:51 +00:00
bool supportsEmbedding ( ) const override { return false ; }
bool supportsCompletion ( ) const override { return true ; }
2023-06-06 21:09:00 +00:00
bool loadModel ( const std : : string & modelPath ) override ;
bool isModelLoaded ( ) const override ;
2023-06-26 19:17:34 +00:00
size_t requiredMem ( const std : : string & modelPath ) override ;
2023-06-06 21:09:00 +00:00
size_t stateSize ( ) const override ;
size_t saveState ( uint8_t * dest ) const override ;
size_t restoreState ( const uint8_t * src ) override ;
void setThreadCount ( int32_t n_threads ) override ;
int32_t threadCount ( ) const override ;
2023-09-14 13:59:19 +00:00
bool usingGPUDevice ( ) override ;
2023-06-06 21:09:00 +00:00
private :
ReplitPrivate * d_ptr ;
protected :
std : : vector < Token > tokenize ( PromptContext & , const std : : string & ) const override ;
2023-06-13 11:14:02 +00:00
std : : string tokenToString ( Token ) const override ;
2023-06-06 21:09:00 +00:00
Token sampleToken ( PromptContext & ctx ) const override ;
bool evalTokens ( PromptContext & ctx , const std : : vector < int32_t > & tokens ) const override ;
int32_t contextLength ( ) const override ;
const std : : vector < Token > & endTokens ( ) const override ;
} ;
# endif // REPLIT_H