-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathCompress_SEAM_Basin.cpp
173 lines (149 loc) · 5.1 KB
/
Compress_SEAM_Basin.cpp
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
#include <assert.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <string>
#include <string.h>
#include <chrono>
#include <omp.h>
#include "CvxCompress.hxx"
#include <iostream>
using namespace std;
//#define VERBOSE
using namespace std;
using std::chrono::system_clock;
typedef std::chrono::system_clock Time;
typedef std::chrono::milliseconds ms;
typedef std::chrono::duration<double> fsec;
int main(int argc, char* argv[])
{
int nx = 320; //slow
int ny = 416; //medium
int nz = 352; //fast
const string filepath = "/cpfs/lfs02/ESDRD/akep/CompressionTest/SEAM1_le.bin";
const string outpath = "compressed_seam_basin.bin";
int bx = 32;
int by = 32;
int bz = 32;
const float scale = 1e-2f;
const bool use_local_RMS = false;
const bool include_block_lengths = false;
printf("Using %s RMS.\n",use_local_RMS?"local":"global");
long overall_compressed = 0;
int num_threads = 0;
#pragma omp parallel
{
num_threads = omp_get_num_threads();
}
long volsize = (long)nz * (long)ny * (long)nx;
long totsize = volsize;
long totsize_b = totsize * 4l;
long compressed_array_size = 5l*totsize_b/4l;
float *vol,*vol2;
posix_memalign((void**)&vol, 64, totsize_b);
posix_memalign((void**)&vol2, 64, totsize_b);
assert(vol != 0L);
assert(vol2 != 0L);
#pragma omp parallel for
for (long ix = 0; ix < (long)nx; ++ix)
{
long nyz = (long)ny * (long)nz;
long idx = ix * nyz;
memset((void*)(vol+idx),0,nyz*4);
memset((void*)(vol2+idx),0,nyz*4);
}
FILE* fp = fopen(filepath.c_str(),"rb");
assert(fp != 0L);
fread(vol,sizeof(float),totsize,fp);
fclose(fp);
unsigned int* compressed;
posix_memalign((void**)&compressed,64, compressed_array_size);
assert(compressed != 0L);
#pragma omp parallel for
for (int ix = 0; ix < ((5l*(long)nx)>>2); ++ix)
{
long nyz = (long)ny * (long)nz;
long idx = ix * nyz;
memset((void*)(compressed+idx),0,nyz*4);
}
double tot_elapsed_time = 0.0;
FILE* fp2 = fopen("results.txt","w");
assert(fp2 != 0L);
printf("Starting compression test\n");
CvxCompress* compressor = new CvxCompress();
long compressed_length;
// check if wavefield has NaN's in it
bool has_NaN = false;
for (long j = 0; j < volsize && !has_NaN; ++j)
{
if (isnan(vol[j])) has_NaN = true;
}
assert(!has_NaN);
for(int ntries=0; ntries<2; ntries++){
auto start = Time::now();
// ********************** COMPRESSING **********************
// float ratio = compressor->Compress_Safe(scale,vol,nz,ny,nx,bz,by,bx,
// use_local_RMS,include_block_lengths,
// compressed,
float ratio = compressor->Compress(scale, vol,
nz,ny,nx,
bz,by,bx,
use_local_RMS,
compressed,
compressed_length);
auto stop = Time::now();
fsec elapsed1 = (stop - start);
double mcells_per_sec1 = (double)(nx * ny * nz) / (elapsed1.count() * 1e6);
tot_elapsed_time += elapsed1.count();
overall_compressed = (long)compressed_length;
start = Time::now();
// ********************** DECOMPRESSING **********************
// compressor->Decompress_Safe(vol2,nz,ny,nx,compressed,compressed_length);
compressor->Decompress(vol2, nz,ny,nx, compressed, compressed_length);
stop = Time::now();
fsec elapsed2 = (stop - start);
double mcells_per_sec2 = (double)nx * (double)ny * (double)nz / (elapsed2.count() * 1e6);
tot_elapsed_time += elapsed2.count();
double acc1=0.0, acc2=0.0, acc3=0.0;
#pragma omp parallel for reduction(+:acc1,acc2,acc3)
for (long idx = 0; idx < volsize; ++idx)
{
double val1 = vol[idx];
double val2 = vol[idx] - vol2[idx];
double val3 = vol2[idx];
acc1 += val1 * val1;
acc2 += val2 * val2;
acc3 += val3 * val3;
}
acc1 = sqrt(acc1/(double)volsize);
acc2 = sqrt(acc2/(double)volsize);
acc3 = sqrt(acc3/(double)volsize);
printf("RMS:\n input: %f\n output: %f\n Difference: %f\n",acc1,acc3,acc2);
double error = acc2 / acc1;
double snr = -20.0 * log10(error);
printf("compression ratio = %.2f:1, compression throughput = %.0f MC/s, decompression throughput = %.0f MC/s, error = %.6e, SNR = %.1f dB\n",
ratio,mcells_per_sec1,mcells_per_sec2,error,snr);
fprintf(fp2,"%.2f, %.6e, %.5f, %.5f, %.0f, %.0f\n",ratio,error,elapsed1.count(),elapsed2.count(),mcells_per_sec1,mcells_per_sec2);
printf("Total compression and decompression times were %.2f seconds\n",tot_elapsed_time);
double overall_ratio = ((double)nx * (double)ny * (double)nz * 4.0) / (double)overall_compressed;
printf("Total compression ratio (all snapshots) was %.2f:1\n",overall_ratio);
// DEBUG
double inMS=0;
for(long i=0; i<totsize; i++) {
inMS += vol[i]*vol[i];
}
double inRMS = sqrt(inMS/totsize);
cout << " Input RMS is " << inRMS << endl;
double norm = 1.0/inRMS;
for(long i=0; i<totsize; i++) {
vol[i] *= norm;
}
inMS = 0;
for(long i=0; i<totsize; i++) {
inMS += vol[i]*vol[i];
}
cout << " Scaled input RMS is " << sqrt(inMS/totsize) << endl;
}
fclose(fp2);
return 0;
}