File: fbgemm_pack_matrix_cache.h

package info (click to toggle)
pytorch 1.13.1%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 139,252 kB
  • sloc: cpp: 1,100,274; python: 706,454; ansic: 83,052; asm: 7,618; java: 3,273; sh: 2,841; javascript: 612; makefile: 323; xml: 269; ruby: 185; yacc: 144; objc: 68; lex: 44
file content (22 lines) | stat: -rw-r--r-- 537 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#pragma once

#include "fbgemm/Fbgemm.h"

namespace caffe2 {

/**
 * If there's an existing packed matrix for the same matrix, reuse it.
 * Create a new one otherwise. This can save memory usage if many threads are
 * sharing the same weight.
 */
template <typename ACC_T>
std::shared_ptr<fbgemm::PackBMatrix<int8_t, ACC_T>>
GetOrCreateFbgemmPackBMatrix(
    fbgemm::matrix_op_t trans,
    std::int32_t m,
    std::int32_t n,
    const void* orig_data,
    const std::int8_t* quantized_data,
    std::int32_t ld);

} // namespace caffe2