Compare commits
No commits in common. '181abacc55f42c32150d04da171b9ff73166efff' and '529c5cb6a8f5b5aa89e74b96d6764acfa0ddbc0a' have entirely different histories.
181abacc55
...
529c5cb6a8
@ -1,72 +0,0 @@
|
|||||||
#include "./server/libaquery.h"
|
|
||||||
|
|
||||||
#ifndef __AQ_USE_THREADEDGC__
|
|
||||||
|
|
||||||
#include "./server/gc.h"
|
|
||||||
__AQEXPORT__(void) __AQ_Init_GC__(Context* cxt) {
|
|
||||||
GC::gc_handle = static_cast<GC*>(cxt->gc);
|
|
||||||
}
|
|
||||||
|
|
||||||
#else // __AQ_USE_THREADEDGC__
|
|
||||||
#define __AQ_Init_GC__(x)
|
|
||||||
#endif // __AQ_USE_THREADEDGC__
|
|
||||||
#include "./server/hasher.h"
|
|
||||||
#include "./server/monetdb_conn.h"
|
|
||||||
#include "./server/aggregations.h"
|
|
||||||
|
|
||||||
__AQEXPORT__(int) dll_2Cxoox(Context* cxt) {
|
|
||||||
using namespace std;
|
|
||||||
using namespace types;
|
|
||||||
auto server = static_cast<Server*>(cxt->alt_server);
|
|
||||||
auto len_4ycjiV = server->cnt;
|
|
||||||
auto mont_8AE = ColRef<const char*>(len_4ycjiV, server->getCol(0));
|
|
||||||
auto sales_2RB = ColRef<int>(len_4ycjiV, server->getCol(1));
|
|
||||||
const char* names_6pIt[] = {"mont", "minw2ysales"};
|
|
||||||
auto out_2LuaMH = new TableInfo<const char*,vector_type<double>>("out_2LuaMH", names_6pIt);
|
|
||||||
decltype(auto) col_EeW23s = out_2LuaMH->get_col<0>();
|
|
||||||
decltype(auto) col_5gY1Dm = out_2LuaMH->get_col<1>();
|
|
||||||
typedef record<decays<decltype(mont_8AE)::value_t>> record_typegj3e8Xf;
|
|
||||||
ankerl::unordered_dense::map<record_typegj3e8Xf, uint32_t, transTypes<record_typegj3e8Xf, hasher>> gMzMTEvd;
|
|
||||||
gMzMTEvd.reserve(mont_8AE.size);
|
|
||||||
uint32_t* reversemap = new uint32_t[mont_8AE.size<<1],
|
|
||||||
*mapbase = reversemap + mont_8AE.size;
|
|
||||||
for (uint32_t i2E = 0; i2E < mont_8AE.size; ++i2E){
|
|
||||||
reversemap[i2E] = gMzMTEvd.hashtable_push(forward_as_tuple(mont_8AE[i2E]));
|
|
||||||
}
|
|
||||||
auto arr_values = gMzMTEvd.values().data();
|
|
||||||
auto arr_len = gMzMTEvd.size();
|
|
||||||
uint32_t* seconds = new uint32_t[gMzMTEvd.size()];
|
|
||||||
|
|
||||||
auto vecs = static_cast<vector_type<uint32_t>*>(malloc(sizeof(vector_type<uint32_t>) * arr_len));
|
|
||||||
vecs[0].init_from(arr_values[0].second, mapbase);
|
|
||||||
for (uint32_t i = 1; i < arr_len; ++i) {
|
|
||||||
vecs[i].init_from(arr_values[i].second, mapbase + arr_values[i - 1].second);
|
|
||||||
arr_values[i].second += arr_values[i - 1].second;
|
|
||||||
}
|
|
||||||
for (uint32_t i = 0; i < mont_8AE.size; ++i) {
|
|
||||||
auto id = reversemap[i];
|
|
||||||
mapbase[--arr_values[id].second] = i;
|
|
||||||
}
|
|
||||||
|
|
||||||
col_EeW23s.reserve(gMzMTEvd.size());
|
|
||||||
col_5gY1Dm.reserve(gMzMTEvd.size());
|
|
||||||
auto buf_col_5gY1Dm = new double[mont_8AE.size];
|
|
||||||
for (uint32_t i = 0; i < arr_len; ++i) {
|
|
||||||
col_5gY1Dm[i].init_from(vecs[i].size, buf_col_5gY1Dm + arr_values[i].second);
|
|
||||||
}
|
|
||||||
for (uint32_t i = 0; i < arr_len; ++i) {
|
|
||||||
|
|
||||||
auto &key_3iNX3qG = arr_values[i].first;
|
|
||||||
auto &val_7jjv8Mo = arr_values[i].second;
|
|
||||||
col_EeW23s.emplace_back(get<0>(key_3iNX3qG));
|
|
||||||
|
|
||||||
avgw(10, sales_2RB[vecs[i]], col_5gY1Dm[i]);
|
|
||||||
|
|
||||||
}
|
|
||||||
//print(*out_2LuaMH);
|
|
||||||
//FILE* fp_5LQeym = fopen("flatten.csv", "wb");
|
|
||||||
out_2LuaMH->printall(",", "\n", nullptr, nullptr, 10);
|
|
||||||
//fclose(fp_5LQeym);
|
|
||||||
puts("done.");
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,51 +0,0 @@
|
|||||||
import struct
|
|
||||||
import readline
|
|
||||||
from typing import List
|
|
||||||
|
|
||||||
name : str = input()
|
|
||||||
|
|
||||||
def write():
|
|
||||||
s : str = input()
|
|
||||||
qs : List[str] = []
|
|
||||||
|
|
||||||
while(len(s) and not s.startswith('S')):
|
|
||||||
qs.append(s)
|
|
||||||
s = input()
|
|
||||||
|
|
||||||
ms : int = int(input())
|
|
||||||
|
|
||||||
with open(f'./procedures/{name}.aqp', 'wb') as fp:
|
|
||||||
fp.write(struct.pack("I", len(qs) + (ms > 0)))
|
|
||||||
fp.write(struct.pack("I", ms))
|
|
||||||
if (ms > 0):
|
|
||||||
fp.write(b'N\x00')
|
|
||||||
|
|
||||||
for q in qs:
|
|
||||||
fp.write(q.encode('utf-8'))
|
|
||||||
if q.startswith('Q'):
|
|
||||||
fp.write(b'\n ')
|
|
||||||
fp.write(b'\x00')
|
|
||||||
|
|
||||||
|
|
||||||
def read():
|
|
||||||
with open(f'./procedures/{name}.aqp', 'rb') as fp:
|
|
||||||
nq = struct.unpack("I", fp.read(4))[0]
|
|
||||||
ms = struct.unpack("I", fp.read(4))[0]
|
|
||||||
qs = fp.read().split(b'\x00')
|
|
||||||
print(f'Procedure {name}, {nq} queries, {ms} modules:')
|
|
||||||
for q in qs:
|
|
||||||
print(' ' + q.decode('utf-8'))
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
while True:
|
|
||||||
cmd = input("r for read, w for write: ")
|
|
||||||
if cmd.lower().startswith('r'):
|
|
||||||
read()
|
|
||||||
break
|
|
||||||
elif cmd.lower().startswith('w'):
|
|
||||||
write()
|
|
||||||
break
|
|
||||||
elif cmd.lower().startswith('q'):
|
|
||||||
break
|
|
||||||
|
|
Loading…
Reference in new issue