pdbench/MayBMS-tpch/uncertain-tpch
2016-10-11 22:54:38 -04:00
..
.gitignore Debugging 2016-10-06 20:31:35 -04:00
bcd2.c Initial import 2016-10-06 19:10:22 -04:00
bcd2.h Initial import 2016-10-06 19:10:22 -04:00
bm_utils.c Debugging 2016-10-06 20:31:35 -04:00
build.c Initial import 2016-10-06 19:10:22 -04:00
config.h Initial import 2016-10-06 19:10:22 -04:00
dbgen.dsp Initial import 2016-10-06 19:10:22 -04:00
dists.dss Initial import 2016-10-06 19:10:22 -04:00
driver.c Initial import 2016-10-06 19:10:22 -04:00
dss-ours.ddl Initial import 2016-10-06 19:10:22 -04:00
dss.ddl Initial import 2016-10-06 19:10:22 -04:00
dss.h Initial import 2016-10-06 19:10:22 -04:00
dss.ri Initial import 2016-10-06 19:10:22 -04:00
dsstypes.h Initial import 2016-10-06 19:10:22 -04:00
load_stub.c Initial import 2016-10-06 19:10:22 -04:00
Makefile Debugging 2016-10-06 20:31:35 -04:00
permute.c Initial import 2016-10-06 19:10:22 -04:00
permute.h Initial import 2016-10-06 19:10:22 -04:00
PORTING.NOTES Initial import 2016-10-06 19:10:22 -04:00
print.c Debugging 2016-10-06 20:31:35 -04:00
qgen.c Initial import 2016-10-06 19:10:22 -04:00
Rakefile Schema generation 2016-10-11 22:54:38 -04:00
README.URELATIONS Initial import 2016-10-06 19:10:22 -04:00
release.h Standard tweaks to make dbgen happy with OSX 2016-10-06 19:23:46 -04:00
rnd.c Initial import 2016-10-06 19:10:22 -04:00
rnd.h Initial import 2016-10-06 19:10:22 -04:00
rng64.c Initial import 2016-10-06 19:10:22 -04:00
rng64.h Initial import 2016-10-06 19:10:22 -04:00
shared.h Initial import 2016-10-06 19:10:22 -04:00
speed_seed.c Initial import 2016-10-06 19:10:22 -04:00
text.c Initial import 2016-10-06 19:10:22 -04:00
tpcd.h Initial import 2016-10-06 19:10:22 -04:00
tpch2.6.0.pdf Initial import 2016-10-06 19:10:22 -04:00
update_release.sh Initial import 2016-10-06 19:10:22 -04:00
varsub.c Standard tweaks to make dbgen happy with OSX 2016-10-06 19:23:46 -04:00

In addition to the standard TPC-H parameters, UTPC-H has three more
parameters:

-x	uncertainty ratio.

-z	(zipf) correlation ratio.

-m	maximum alternatives per uncertain cell.

 such as scale (-s 1 for
1GB of data)


The (standard dbgen) parameter "s" is used to control the size of each
world (-s 1 means that each world has size 1 GB). The uncertainty
ratio (x) controls the percentage of (uncertain) fields with several
possible values, and the parameter "m" controls how many possible
values can be assigned to a field. The parameter "z" defines a Zipf
distribution for the variables with different dependent field counts
(DFC). The DFC of a variable is the number of tuple fields dependent
on that variable. We use the parameter "z" to control the attribute
correlations: For "n" uncertain fields, there are ceiling(C*z^{i})
variables with DFC "i", where 

	C = n(z-1)/(z^{k+1} - 1), 

i.e., n is sum of (C*z^i) with i from 0 to k. Thus greater z-values
correspond to higher correlations in the data.  The number of domain
values of a variable with DFC k>1 is chosen using the formula

	p^{k-1}*(Product of m_i with i from 1 to k), 

where "m_i" is the number of different values for the "i"-th field
dependent on that variable, and "p" is the probability that a
combination of possible values for the "k" fields is valid. This
assumption fits naturally to data cleaning scenarios (work by the
MAyBMS team, ICDE'07, on chasing dependencies on world-set
decompositions)

By default, after correlating two variables with arbitrary DFCs, only
$p*100$ percent of the combinations satisfy the constraints and are
preserved. The value of "p" can be changed in the code (no in put
parameter to date).

The uncertain fields are assigned randomly to variables. This can lead
to correlations between fields belonging to different tuples or even
to different relations. This fits to scenarios where constraints are
enforced across tuples or relations.