/usr/include/shogun/lib/Hash.h is in libshogun-dev 3.1.1-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 | /*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* Written (W) 2009 Soeren Sonnenburg
* Copyright (C) 2009 Fraunhofer Institute FIRST and Max-Planck-Society
*
* The MD5 hashing function was integrated from public sources.
* Its copyright follows.
*
* MD5
*
* This code implements the MD5 message-digest algorithm.
* The algorithm is due to Ron Rivest. This code was
* written by Colin Plumb in 1993, no copyright is claimed.
* This code is in the public domain; do with it what you wish.
*
* Equivalent code is available from RSA Data Security, Inc.
* This code has been tested against that, and is equivalent,
* except that you don't need to include two pages of legalese
* with every copy.
*
* To compute the message digest of a chunk of bytes, declare an
* MD5Context structure, pass it to MD5Init, call MD5Update as
* needed on buffers full of bytes, and then call MD5Final, which
* will fill a supplied 16-byte array with the digest.
*
*/
#ifndef HASH_H
#define HASH_H
#include <shogun/base/SGObject.h>
#include <shogun/lib/common.h>
#include <shogun/lib/external/PMurHash.h>
namespace shogun
{
/** @brief Collection of Hashing Functions
*
* This class implements a number of hashing functions like
* crc32, md5 and murmur.
*
*/
class CHash : public CSGObject
{
public:
/** default constructor */
CHash() {}
/** default destructor */
virtual ~CHash() {}
/** crc32 checksumming
*
* @param data data to checksum
* @param len length in number of bytes
*/
static uint32_t crc32(uint8_t *data, int32_t len);
/** Wrapper for MD5 function compatible to OpenSSL interface.
*
* @param x data
* @param l length
* @param buf buf needs to provide an allocated array of 16 bytes
* for the digest.
*/
static void MD5(unsigned char *x, unsigned l, unsigned char *buf);
/** Murmur Hash3
* Wrapper for function in PMurHash.c
*
* @param data data to checksum (needs to be 32bit aligned on some archs)
* @param len length in number of bytes
* @param seed initial seed
*
* @return hash
*/
static uint32_t MurmurHash3(uint8_t* data, int32_t len, uint32_t seed);
/** Incremental Murmur3 Hash. Wrapper for function in PMurHash.c
* FinalizeIncrementalMurmurHash3 must be called
* at the end of all incremental hashing to
* obtain final hash.
*
* @param hash value. (The value returned is not the final hash).
* @param carry value for incremental hash. See PMurHash.c for details.
* @param data data to checksum (needs to be 32bit aligned on some archs)
* @param len length in number of bytes
*
*/
static void IncrementalMurmurHash3(uint32_t *hash, uint32_t *carry,
uint8_t* data, int32_t len);
/** Finalize Incremental Murmur Hash. Called when all
* incremental hashing is done to get final hash value.
*
* Wrapper for function in PMurHash.c
*
* @param h hash returned by IncrementalMurmurHash3
* @param carry returned by IncrementalMurmurHash3
* @param total_length total length of all bytes hashed.
*
*/
static uint32_t FinalizeIncrementalMurmurHash3(uint32_t h,
uint32_t carry, uint32_t total_length);
/** Apply Murmur Hash on the non-numeric part of
* a substring.
*
* The integral part is returned as-is.
*
* @param s substring
* @param h initial seed
*
* @return hash
*/
static uint32_t MurmurHashString(substring s, uint32_t h);
/** @return object name */
virtual const char* get_name() const { return "Hash"; }
protected:
#ifndef DOXYGEN_SHOULD_SKIP_THIS
/** MD5Context */
struct MD5Context {
/** 16 byte buffer */
uint32_t buf[4];
/** 8 byte buffer */
uint32_t bits[2];
union
{
/** 64 byte buffer */
unsigned char in[64];
/** and equivalently 16 uint32's */
uint32_t uin[16];
};
};
#endif // DOXYGEN_SHOULD_SKIP_THIS
/**
* Start MD5 accumulation. Set bit count to 0 and buffer to mysterious
* initialization constants.
*
* @param context MD5Context
*/
static void MD5Init(struct MD5Context *context);
/**
* Update context to reflect the concatenation of another buffer full
* of bytes.
*
* @param context initialized MD5Context
* @param buf buffer to hash
* @param len length of buffer
*/
static void MD5Update(struct MD5Context *context,
unsigned char const *buf, unsigned len);
/**
* Final wrapup - pad to 64-byte boundary with the bit pattern
* 1 0* (64-bit count of bits processed, MSB-first)
*
* @param digest the 64 byte hash
* @param context initialized MD5Context
*/
static void MD5Final(unsigned char digest[16],
struct MD5Context *context);
/**
* The core of the MD5 algorithm, this alters an existing MD5 hash to
* reflect the addition of 16 longwords of new data. MD5Update blocks
* the data and converts bytes into longwords for this routine.
*
* @param buf 16 byte
* @param in 64 bytes
*/
static void MD5Transform(uint32_t buf[4], uint32_t const in[16]);
};
}
#endif
|