Skip to content

Latest commit

 

History

History
50 lines (35 loc) · 2.53 KB

memorization_scaling_law.md

File metadata and controls

50 lines (35 loc) · 2.53 KB

memorization scaling law

labels: experimentation, scaling, learning_theory

  1. for any given model architecture and input representation, we can fit a distribution over the number of steps required to memorize that datum to within some fixed tolerance
  2. rinse and repeat, increasing the number of inputs to be memorized. we now have a likelihood over ht e number of steps required to memorize some fixed dataset size
  3. extrapolate up to give an information-theoretic distribution over the upper bound for time required to fit that dataset
  4. correlate to empirical results to estimate some measure of the "information density" of representations from a given dataset as a ratio relative to whatever the "naive" density was.

this "information density" idea is interesting. I guess I could use some kind of simple toy dataset

ok ohere how about this

we don't sample a dataset, we sample a network, so we're also parameterizing this experiment relative to a particular feasible space. imposing simple constraints on the feasible space might help in various ways.

but ok, let's say theta is some latent for the space of models. we sample a set of weights W1 and use this as our target model. it is frozen and will be used to generate the objective. draw another sample W2, call this the ... ok, W1 is the teacher, and W2 is the student. this is just student teacher learning. so the question is: how long does it take to fit the student, given we constrain ourselves to a dataset of some fixed size.

now from this teacher-student model, we can infer properties over the limits for the efficiency of learning a distribution parameters some given way (the weights) given a dataset of fixed size and an error tolerance.

fuck it, let's pseudocode.

# this should really highlight, github. this would highlight if you were a little cooler.

prior = sample_prior_parameters()
student = sample_a_model(prior)
teacher = sample_a_model(prior)
teacher.frozen()

records = []
n = max_number_of_observations_to_memorize
for i in range(n):
  x = sample_input(size=n)
  y = teacher(x)
  recs = []
  for _ in range(mc_repetitions):
    with m:= steps_required_to_fit_within_tolerance(tol):
      student.fit(x,y)
      recs.append((m,n,tol))
    records.appends(summarize(recs)
plot.kde(records)

lol is this just chinchilla? possibly very similar to this: https://github.com/kyo-takano/chinchilla

chinchilla ref: https://arxiv.org/abs/2203.15556


related idea though: overfit a model on a small dataset to compress the dataset into the model. or even just into a LoRA.