User:IssaRice/Logical inductor construction: Difference between revisions

From Machinelearning
 
(52 intermediate revisions by the same user not shown)
Line 3: Line 3:
==Lemma 5.1.1 (Fixed Point Lemma)==
==Lemma 5.1.1 (Fixed Point Lemma)==


"Observe that <math>\mathcal V'</math> is equal to the natural inclusion of the finite-dimensional cube <math>[0,1]^{\mathcal S'}</math> in the space of all valuations <math>\mathcal V = [0,1]^{\mathcal S}</math>." -- I think what this is saying is that since <math>\mathcal S' \subset \mathcal S</math>, we can think of <math>[0,1]^{\mathcal S'}</math> as being sort of a subset of <math>[0,1]^{\mathcal S}</math>. Except it's not strictly speaking a subset, since the functions in <math>[0,1]^{\mathcal S'}</math> and <math>[0,1]^{\mathcal S}</math> have different domains. How can we make it a subset? The "natural" way to do this is to set everything outside of <math>\mathcal S'</math> to zero. But that's exactly what <math>\mathcal V' = \{\mathbb V \in [0,1]^{\mathcal S} : \mathbb V(\phi) = 0 \text{ whenever }\phi \notin \mathcal S'\}</math> is. One thing I'm still not sure about is the "finite-dimensional" part; doesn't having <math>[0,1]</math> make the cube infinite-dimensional?
"Observe that <math>\mathcal V'</math> is equal to the natural inclusion of the finite-dimensional cube <math>[0,1]^{\mathcal S'}</math> in the space of all valuations <math>\mathcal V = [0,1]^{\mathcal S}</math>." -- I think what this is saying is that since <math>\mathcal S' \subset \mathcal S</math>, we can think of <math>[0,1]^{\mathcal S'}</math> as being sort of a subset of <math>[0,1]^{\mathcal S}</math>. Except it's not strictly speaking a subset, since the functions in <math>[0,1]^{\mathcal S'}</math> and <math>[0,1]^{\mathcal S}</math> have different domains. How can we make it a subset? The "natural" way to do this is to set everything outside of <math>\mathcal S'</math> to zero. But that's exactly what <math>\mathcal V' = \{\mathbb V \in [0,1]^{\mathcal S} : \mathbb V(\phi) = 0 \text{ whenever }\phi \notin \mathcal S'\}</math> is. One thing I'm still not sure about is the "finite-dimensional" part; doesn't having <math>[0,1]</math> make the cube infinite-dimensional? -- it's finite-dimensional, since if <math>\mathcal S'</math> is a finite set, we can think of <math>[0,1]^{\mathcal S'}</math> as being basically <math>[0,1]^n = [0,1]\times \cdots \times [0,1]</math>, where <math>n = |\mathcal S'|</math>.


Definition of fix: I found it helpful to look at the [https://www.wolframalpha.com/input/?i=plot+f(x)+%3D+max(0,+min(1,+x)) graph] of <math>f(x) = \max(0, \min(1, x))</math>; this looks like the identity function in the interval <math>[0,1]</math>, but then becomes constant once it hits either of the endpoints. If you've already thought about the definition of continuous threshold indicator (definition 4.3.2), then you will recognize that <math>f(x) = \mathrm{Ind}_1(x > 0)</math>.
Definition of fix: I found it helpful to look at the [https://www.wolframalpha.com/input/?i=plot+f(x)+%3D+max(0,+min(1,+x)) graph] of <math>f(x) = \max(0, \min(1, x))</math>; this looks like the identity function in the interval <math>[0,1]</math>, but then becomes constant once it hits either of the endpoints. If you've already thought about the definition of continuous threshold indicator (definition 4.3.2), then you will recognize that <math>f(x) = \mathrm{Ind}_1(x > 0)</math>.


"the compact, convex space <math>\mathcal V'</math>" -- this intuitively makes sense, since <math>\mathcal V'</math> basically "looks like" a cube. But I'm not sure how to verify this.
"the compact, convex space <math>\mathcal V'</math>" -- this intuitively makes sense, since <math>\mathcal V'</math> basically "looks like" a cube. But I'm not sure how to verify this. -- Here's what I eventually came up with: in order to talk about a set being "compact" or "convex", we need some kind of structured space. But what kind of structured space? we can have metric spaces, normed spaces, inner product spaces, vector spaces, topological spaces, and on and on. The paper doesn't tell us what kind of space, so we have to figure it out on our own. Ok. But knowing the words "compact" and "convex", we can restrict what kind of space it can be. In particular, one way to go about this is to take the most general kind of structured space that each adjective ("compact" or "convex") can apply to, and then take the less general of the two, which gives us the most general kind of space that can take both adjectives. Now, theoretically, there can be a problem here, where when we do that, we get two spaces that are not comparable (formally: we have a partial order of structured spaces, and we are finding subsets of this partial order that can take each adjective, and then finding the maximum of the union, but because we're working on a partial order, a maximum might not exist -- we might just have a bunch of maximal elements). Luckily, in this case we don't need to worry about this problem... Anyway, compactness makes sense for topological spaces, which are very general. And convexity requires us to be able to add elements and scale them (since we need to form the expression <math>(1-t)v + tw</math> for <math>t\in [0,1]</math>). So maybe it's a topological vector space, but actually we don't need to be so general. I think we can just think of our space as being the subset <math>[0,1]^n</math> of the Euclidean space <math>\mathbf R^n</math>. I'm not entirely confident though; the paper talks about "the space of all valuations <math>\mathcal V = [0,1]^{\mathcal S}</math>", so maybe that's supposed to be the ambient space.


For the fixed point reasoning: we don't actually have a fixed point of <math>f</math>; instead, it's a fixed point of <math>g</math>, where <math>g(x) = f(x+\delta)</math> and <math>\delta = T_n(\mathbb P_{\leq n-1}, \mathbb V^\text{fix})[\phi]</math>. If <math>\delta > 0</math>, then the graph of <math>g</math> is just the graph of <math>f</math> but shifted to the left. You will see that this intersects the graph of the identity function at <math>x=1</math>; this is the fixed point. On the other hand, if <math>\delta < 0</math>, then we shift the graph of <math>f</math> to the right, and now the fixed point is at <math>x=0</math>.
For the fixed point reasoning: we don't actually have a fixed point of <math>f</math>; instead, it's a fixed point of <math>g</math>, where <math>g(x) = f(x+\delta)</math> and <math>\delta = T_n(\mathbb P_{\leq n-1}, \mathbb V^\text{fix})[\phi]</math>. If <math>\delta > 0</math>, then the graph of <math>g</math> is just the graph of <math>f</math> but shifted to the left. You will see that this intersects the graph of the identity function at <math>x=1</math>; this is the fixed point. On the other hand, if <math>\delta < 0</math>, then we shift the graph of <math>f</math> to the right, and now the fixed point is at <math>x=0</math>.
Line 19: Line 19:
Something else I got confused about: I was thinking that the above key property only talks about day <math>n</math>. Couldn't the trader make a lot of money on previous days, and then just make no money on day <math>n</math>, so that it would still be making lots of money? The answer is that we are only dealing with a trading ''strategy'' in this lemma, not a full trader. Later, in lemma 5.1.3, we recursively use this idea to deal with a full trader.
Something else I got confused about: I was thinking that the above key property only talks about day <math>n</math>. Couldn't the trader make a lot of money on previous days, and then just make no money on day <math>n</math>, so that it would still be making lots of money? The answer is that we are only dealing with a trading ''strategy'' in this lemma, not a full trader. Later, in lemma 5.1.3, we recursively use this idea to deal with a full trader.


How do we come up with the definition of fix? Here's one way to think about it. Let <math>x</math> be the market price (of some sentence on day <math>n</math>) and <math>\delta</math> be the trading volume of that sentence on the same day. We want to return some quantity <math>f(x,\delta)</math> that fixes up the price, after the fact, so that the trader would have earned less money. Why after the fact? Because doing it in real time is confusing! The trader depends on the prices for day n, which is what we want to decide. But we want to know what the trader does on day n in order to determine the prices. So there is a circular dependency. Ideally we would like to say something like:
How do we come up with the definition of fix? Here's one way to think about it. Let <math>x</math> be the market price (of some sentence on day <math>n</math>) and <math>\delta</math> be the trading volume of that sentence on the same day. We want to return some quantity <math>f(x,\delta)</math> that fixes up the price, after the fact, so that the trader would have earned less money. Why after the fact? Because doing it in real time is confusing! The trader depends on the prices for day n, which is what we want to decide. But we want to know what the trader does on day n in order to determine the prices. So there is a circular dependency. This sort of thing happens in game theory too, where everything ''does'' eventually take place in real time, but we can think iteratively by "pressing pause" and considering counterfactuals and going down different paths in the game tree. Here is another way to think about it. We get an infinite number of "retries". We first set the price to something arbitrary. Then we get to see what the trader would do in that situation. Ah, it buys some shares, making money in expectation. We want to prevent that, so we pretend that wasn't the ''real'' market price, and see what the trader does in the new, adjusted price. It's also a hint that fixed points are going to appear. Ideally we would like to say something like:


:<math>f(x,\delta) = \begin{cases} 1 & \text{if } \delta > 0 \\ x & \text{if } \delta=0 \\ 0 & \text{if } \delta < 0 \end{cases}</math>
:<math>f(x,\delta) = \begin{cases} 1 & \text{if } \delta > 0 \\ x & \text{if } \delta=0 \\ 0 & \text{if } \delta < 0 \end{cases}</math>
Line 25: Line 25:
This will work, but it's after the fact. We eventually would like to fix the prices in real time. So one way to think about this is to adjust the prices a little at a time, querying the trading strategy each time to see if we should nudge the prices up or down. Here is one idea:
This will work, but it's after the fact. We eventually would like to fix the prices in real time. So one way to think about this is to adjust the prices a little at a time, querying the trading strategy each time to see if we should nudge the prices up or down. Here is one idea:


:<math>f(x,\delta) = \begin{cases} x-\epsilon & \text{if } \delta > 0 \\ x & \text{if }\delta=0 \\ x+\epsilon & \text{if }\delta < 0 \end{cases}</math>
:<math>f(x,\delta) = \begin{cases} x+\epsilon & \text{if } \delta > 0 \\ x & \text{if }\delta=0 \\ x-\epsilon & \text{if }\delta < 0 \end{cases}</math>


where <math>\epsilon > 0</math> is some small adjustment. In other words, if a trader buys at the current price, then nudge it up a little to make it a slightly worse deal for the trader. And if the trader sells at the current price, then nudge it down. Now, there are three problems with this map. As a function of <math>\delta</math>, it's still discontinuous (ugly). Also, we don't check whether the values we return stay within the allowed <math>[0,1]</math> interval of valuations. But most importantly, if we only adjust the prices a little, that means the trader can still make money from us. So what can we do? Well, we can apply the map many times: <math>f(f(f(f(f(x,\delta),\delta),\delta),\delta), \delta)</math> (actually, maybe we should allow the <math>\delta</math>s to change as well, to react in response). Now it's like a turn-based game: the trader says he's going to buy, so we adjust up; the trader still says he's buying, so we adjust up again; the trader now says he's going to sell, so we adjust down (oops, now we're in exactly the same spot, leading to an infinite loop...).
where <math>\epsilon > 0</math> is some small adjustment. In other words, if a trader buys at the current price, then nudge it up a little to make it a slightly worse deal for the trader. And if the trader sells at the current price, then nudge it down. Now, there are three problems with this map. As a function of <math>\delta</math>, it's still discontinuous (ugly). Also, we don't check whether the values we return stay within the allowed <math>[0,1]</math> interval of valuations. But most importantly, if we only adjust the prices a little, that means the trader can still make money from us. So what can we do? Well, we can apply the map many times: <math>f(f(f(f(f(x,\delta),\delta),\delta),\delta), \delta)</math> (actually, maybe we should allow the <math>\delta</math>s to change as well, to react in response). Now it's like a turn-based game: the trader says he's going to buy, so we adjust up; the trader still says he's buying, so we adjust up again; the trader now says he's going to sell, so we adjust down (oops, now we're in exactly the same spot, leading to an infinite loop...).
Line 31: Line 31:
We can fix the second problem above with the following:
We can fix the second problem above with the following:


:<math>f(x,\delta) = \begin{cases} \max(0,x-\epsilon) & \text{if } \delta > 0 \\ x & \text{if }\delta=0 \\ \min(1,x+\epsilon) & \text{if }\delta < 0 \end{cases}</math>
:<math>f(x,\delta) = \begin{cases} \min(1,x+\epsilon) & \text{if } \delta > 0 \\ x & \text{if }\delta=0 \\ \max(0,x-\epsilon) & \text{if }\delta < 0 \end{cases}</math>


Now if the prices go out of bounds, they get adjusted back to the bound, but otherwise they are unaffected.
Now if the prices go out of bounds, they get adjusted back to the bound, but otherwise they are unaffected.


TODO: make trader map to make the iteration explicit.
Let <math>t: [0,1] \to \mathbb R</math> be a trading strategy that takes the price of a sentence and outputs how much it would trade at that price. So then we start with some price <math>x_1</math>, which gets fed into <math>t</math> to get <math>\delta_1 = t(x_1)</math>. Then we have the next price <math>x_2 = f(x_1, \delta_1)</math>. And the next trade volume is <math>\delta_2 = t(x_2)</math> and so on. So we get <math>f(f(x_1, t(x_1)), t(f(x_1, t(x_1))))</math>.


So what can we do to avoid the infinite loop? One idea might be to decrease the step size <math>\epsilon</math> with time (the number of iterations). This sort of thing is reminiscent of some versions of gradient descent. Another idea is to make the step size a function of <math>\delta</math>: if the trader trades a lot, then we adjust a lot, but if the trader trades only a little, it signals that we're getting close to ... a fixed point!
So what can we do to avoid the infinite loop? One idea might be to decrease the step size <math>\epsilon</math> with time (the number of iterations). This sort of thing is reminiscent of some versions of gradient descent. Another idea is to make the step size a function of <math>\delta</math>: if the trader trades a lot, then we adjust a lot, but if the trader trades only a little, it signals that we're getting close to ... a fixed point!
:<math>f(x,\delta) = \begin{cases} \min(1,x+|\delta|) & \text{if } \delta > 0 \\ x & \text{if }\delta=0 \\ \max(0,x-|\delta|) & \text{if }\delta < 0 \end{cases}</math>
This turns out to be equivalent to <math>\max(0, \min(1, x+\delta))</math>, which is the form of fix given in the paper. To see this, just split into cases based on <math>\delta > 0</math>, <math>\delta = 0</math>, or <math>\delta < 0</math>. The version in the paper makes it obvious that the function is continuous, but it is more difficult to see what is going on.
We want some <math>x</math> such that <math>x = f(x, t(x))</math>, i.e. we are satisfied with the price so that we don't try to change it. Thanks to <math>f,t</math> both being continuous, this is guaranteed by Brouwer's fixed point theorem.
We imagined that we were working with just one sentence, but it turns out that (for some reason) basically the same thing works when dealing with all sentences.
Another thing to wonder is that the rate of adjustment is just <math>1 \cdot \delta</math>. What if we did <math>2\cdot \delta</math> instead? or <math>\delta/2</math>? or <math>\delta^2</math>? It seems like these would change the slope of the graph of <math>f(x,t(x))</math>, which means we might introduce more fixed points (just graph the identity function with the new functions); one of the nice things about slope=1 is that it is parallel to the identity function, so we get exactly one fixed point, or infinitely many. Actually, the scalar on x is still 1, so this probably doesn't matter.


The following is used in the Fixed Point Lemma (5.1.1):
The following is used in the Fixed Point Lemma (5.1.1):
Line 50: Line 60:


But <math>\phi_j^{*n}(\mathbb P_{\leq n-1}, \mathbb V) = \mathbb V(\phi_j)</math> so the two sums cancel to obtain <math>0</math>.
But <math>\phi_j^{*n}(\mathbb P_{\leq n-1}, \mathbb V) = \mathbb V(\phi_j)</math> so the two sums cancel to obtain <math>0</math>.
I think here is a simpler way to do the summation at the end: Write <math>T_n(\mathbb P_{\leq n-1}, \mathbb V)[\phi]</math> as <math>\xi_\phi</math>. Then we have <math display="block">\begin{align}\sum_{\phi \in \mathcal S}(\mathbb W(\phi) - \mathbb V^\text{fix}(\phi)) \cdot \xi_\phi &= \mathbb W\left(\sum_{\phi\in\mathcal S} (\phi - \mathbb V^\text{fix}(\phi))\xi_\phi\right) \\ &= \mathbb W\left(\sum_{\phi\in\mathcal S} (\phi-\phi^{*n}(\mathbb P_{\leq n-1}, \mathbb V^\text{fix})) \xi_\phi\right) \\ &= \mathbb W(T_n(\mathbb P_{\leq n-1}, \mathbb V^\text{fix}))\end{align}</math> where the first equality follows from the linearity of <math>\mathbb W</math>, the second because <math>\phi^{*n}(\mathbb P_{\leq n-1},\mathbb V^\text{fix}) = \mathbb V^\text{fix}(\phi)</math>, and the third because we can change the summation from <math>\phi\in\mathcal S</math> to <math>\phi \in \mathcal S'</math> and by the definition of <math>T_n</math>.


==Definition/Proposition 5.1.2 (MarketMaker)==
==Definition/Proposition 5.1.2 (MarketMaker)==
Define <math>f : [0,1]^{\mathcal S} \to \mathbb R</math> by <math>f(\mathbb V) = \max_{\mathbb W' \in \mathcal W'} \mathbb W'(T_n(\mathbb P_{\leq n-1}, \mathbb V))</math> (this is the same map given in the proof).
Let's see what <math>f</math> does to <math>\mathbb V^\text{fix}</math>. By the Fixed Point Lemma, for any <math>\mathbb W</math> we have <math>\mathbb W'(T_n(\mathbb P_{\leq n-1}, \mathbb V^\text{fix})) \leq 0</math>. This means that as we max over these worlds, we will never exceed 0. So <math>f(\mathbb V^\text{fix}) \leq 0</math>. Or in other words <math>f(\mathbb V^\text{fix}) \in (-\infty, 0] \subset (-\infty, 2^{-n})</math>. (I had two confusions here: first, for some reason I mistakenly thought <math>2^{-n}</math> was negative for a while, so got confused about why <math>f(\mathbb V^\text{fix})</math> was always contained in the interval. Second, I wondered why the left endpoint was minus infinity; couldn't any negative number also work? it couldn't, because we don't know how negative the trader could be; in other words, the trader could perform arbitrarily badly and we don't have a lower bound on that.)
What I'm not sure about is why we need to do this <math>\max_{\mathbb W' \in \mathcal W'}</math> thing. Couldn't we fix some <math>\mathbb W</math> at the start, and consider the map <math>\mathbb V \mapsto \mathbb W(T_n(\mathbb P_{\leq n-1}, \mathbb V))</math>? Then by the same reasoning, for <math>\mathbb V^{\text{fix}}</math> maps into <math>(-\infty, 2^{-n})</math> so we have a neighborhood in <math>\mathcal V'</math> that maps into this open set. It seems like we didn't need to form the max over all the worlds. Of course, doing this <math>\mathbb W'</math> stuff becomes important when doing the brute force search later in the proof, but if we're merely trying to verify the pricing exists, it doesn't seem like we need to do this finite support stuff.
"Hence there is some neighborhood in <math>\mathcal V'</math> around <math>\mathbb V^\text{fix}</math> with image in <math>(-\infty,2^{-n}) \subset \mathbb R</math>." -- This uses one of the equivalent definitions of continuity (often called the topological definition of continuity), namely, <math>f : X \to Y</math> is continuous iff for every open set <math>V \subset Y</math> such that <math>f(x_0) \in V</math>, there exists an open set <math>U \subset X</math> such that <math>x_0\in U</math> and <math>f(U) \subset V</math>. Here we know that <math>(-\infty,2^{-n})</math> is open and <math>f(\mathbb V^\text{fix}) \in (-\infty, 2^{-n})</math>. So there exists an open set <math>U \subset \mathcal V'</math> such that <math>f(\mathbb V^\text{fix}) \in U</math> and <math>f(U) \subset (-\infty,2^{-n})</math>.
One thing I'm unclear on is, are we using a metric on <math>\mathcal V'</math>? If so, what is the metric?


==Lemma 5.1.3 (MarketMaker Inexploitability)==
==Lemma 5.1.3 (MarketMaker Inexploitability)==
This proof is pretty simple.
We use the geometric series <math>\sum_{i=0}^\infty 2^{-i} = \frac1{1-1/2}= 2</math>. (Then subtract <math>2^0 = 1</math> since index starts at 1 rather than 0.)


==Definition/Proposition 5.2.1 (Budgeter)==
==Definition/Proposition 5.2.1 (Budgeter)==
Why does Budgeter get all of <math>\overline D</math>? It seems to use only <math>D_m</math> up to <math>m \leq n</math>.
What's up with the then-clause? Does it even trigger? I think it's just there to make sure Budgeter is defined in all cases. The else-clause doesn't make sense for some values of <math display="inline">\mathbb W(\sum_{i \leq n-1} T_i(\mathbb P_{\leq i}))</math>.
Another question I had was why the budget <math>b</math> is a positive integer, rather than a positive rational. After all, our markets run on rational prices. I think this is because in the way TradingFirm is constructed, all we care about is that we can increase the budget as much as we want, to let the good traders do what they want. The key property is Lemma 5.2.2.3. So basically we just need a subset of the rationals that is not bounded above. I think <math>\mathbb N^+</math> also works well because it's very easy to enumerate (maybe also it's important that it's easy to enumerate in increasing order).
For the inf expression in the else-clause: the fact that we're in the else-clause means that the "if" part is false, so for <math>n-1</math> (which is less than <math>n</math>) in particular, the sum <math display="inline">\mathbb W(\sum_{i \leq n-1} T_i(\mathbb P_{\leq i})) > -b</math>. So the denominator <math display="inline">\mathbb W(\sum_{i \leq n-1} T_i(\mathbb P_{\leq i})) + b > 0</math>. Now suppose that according to <math>\mathbb W</math>, the trader wins money on day n. Then <math>-\mathbb W(T_n)</math> is negative, so that the whole fraction is negative. Thus the output of max is 1, so that Budgeter returns <math>T_n</math>. In other words, if the trader is going to win money anyway, then Budgeter does not interfere with what the trader is doing.
But now suppose that according to <math>\mathbb W</math>, the trader loses money on day n. Thus <math>-\mathbb W(T_n)</math> is positive. As long as the amount of money lost is within the wealth of the trader (which is <math display="inline">\mathbb W(\sum_{i \leq n-1} T_i(\mathbb P_{\leq i})) + b</math>, the expression in the denominator), the fraction is at most 1, so max outputs 1. In other words, Budgeter does nothing because the trader "stays within budget". However, if the trader loses a lot of money on day n, so that it loses more than the wealth it has gained up to that point, then Budgeter kicks in. Suppose I have $10 and am about to lose $30. To stay within my budget I would have to spend at most $10, i.e. I would need to scale my spending by <math>10/30 = (30/10)^{-1}</math>. The same idea applies to the case of Budgeter, where <math>-\mathbb W(T_n)</math> is the amount I would have spent ($30) and <math display="inline">\mathbb W(\sum_{i \leq n-1} T_i(\mathbb P_{\leq i})) + b</math> is the amount I actually have ($10). Why do we take the inf over possible worlds? Because we want to defend against the worst case scenario. Suppose I have $10 (for certain), but now Alice says I am about to lose $30 and Bob says I am about to lose $50. Now, I don't know which of Alice or Bob is right, but I know that at least one of them is right. In order to guarantee that I won't overspend, I must scale my spending by 10/50, because that is the more pessimistic of the scenarios: if Bob is right, then I lose $50 * (10/50) = $10, and if Alice is right I lose $30*(10/50) = $6, so in either case I stay within my budget. And indeed we have <math>10/50 = \inf\{(30/10)^{-1}, (50/10)^{-1}\}</math>.


==Lemma 5.2.2 (Properties of Budgeter)==
==Lemma 5.2.2 (Properties of Budgeter)==
===Part 1===
If the trader never overspends, then budgeter does nothing. The proof of this is basically the same as the reasoning in the previous section.
===Part 2===
If we inductively alter the trader on every single day, then we never overspend.
It seems like a simple inductive proof could work here, but instead we get a horrid thing. Actually it seems like the same proof.
"(since <math>\mathbb W(T_n(\overline{\mathbb P})) < 0</math>)" -- it took me a while to understand what they were doing here. What they're saying is that normally when you take off the "inf" and instantiate it to a specific thing in the class, the expression should go ''up'' but instead here it goes ''down'', and the reason it does that is that the <math>\mathbb W(T_n(\overline{\mathbb P}))</math> at the front of the expression is negative, so it reverses things. I had mistakenly been staring at the <math>\mathbb W(T_n(\overline{\mathbb P}))</math> inside the max, so was confused about this.
===Part 3===
If the trader can exploit the market, then we can give it the budget it needs so that it can do its thing.


==Proposition 5.3.1 (Redundant Enumeration of e.c. Traders)==
==Proposition 5.3.1 (Redundant Enumeration of e.c. Traders)==
I think the key point of this proof is that the <math>n</math> in <math>M(n)</math> is the same as the <math>n</math> in <math>f(n)</math>, so that the input to the trader computation (which says what day it is) controls how long the computation can run.
Suppose we tried skipping the enumeration of the polynomials. Given <math>n</math>, we could decode it into a pair of integers <math>i,j</math>, and run <math>M(i)</math> for <math>j</math> steps. This would find all e.c. traders, but it would also find traders who aren't e.c., because the runtime isn't connected to the input to <math>M</math>.
But given an <math>n</math>-strategy, shouldn't we be able to tell whether it is e.c. or not?


==Definition/Proposition 5.3.2 (TradingFirm)==
==Definition/Proposition 5.3.2 (TradingFirm)==
Why do we want to blank out the traders by defining <math>S^k_n</math>? shouldn't giving the later traders less weight be sufficient? This assumption is used to make the sum <math>\sum_{k \in \mathbb N^+}</math> into <math>\sum_{k \leq n}</math>. In other words, on any day we are only dealing with a finite number of traders.


==Lemma 5.3.3 (Trading Firm Dominance)==
==Lemma 5.3.3 (Trading Firm Dominance)==

Latest revision as of 05:35, 1 August 2019

Notes from the Logical Induction paper as I walk through the construction of LIA in section 5.

Lemma 5.1.1 (Fixed Point Lemma)

"Observe that is equal to the natural inclusion of the finite-dimensional cube in the space of all valuations ." -- I think what this is saying is that since , we can think of as being sort of a subset of . Except it's not strictly speaking a subset, since the functions in and have different domains. How can we make it a subset? The "natural" way to do this is to set everything outside of to zero. But that's exactly what is. One thing I'm still not sure about is the "finite-dimensional" part; doesn't having make the cube infinite-dimensional? -- it's finite-dimensional, since if is a finite set, we can think of as being basically , where .

Definition of fix: I found it helpful to look at the graph of ; this looks like the identity function in the interval , but then becomes constant once it hits either of the endpoints. If you've already thought about the definition of continuous threshold indicator (definition 4.3.2), then you will recognize that .

"the compact, convex space " -- this intuitively makes sense, since basically "looks like" a cube. But I'm not sure how to verify this. -- Here's what I eventually came up with: in order to talk about a set being "compact" or "convex", we need some kind of structured space. But what kind of structured space? we can have metric spaces, normed spaces, inner product spaces, vector spaces, topological spaces, and on and on. The paper doesn't tell us what kind of space, so we have to figure it out on our own. Ok. But knowing the words "compact" and "convex", we can restrict what kind of space it can be. In particular, one way to go about this is to take the most general kind of structured space that each adjective ("compact" or "convex") can apply to, and then take the less general of the two, which gives us the most general kind of space that can take both adjectives. Now, theoretically, there can be a problem here, where when we do that, we get two spaces that are not comparable (formally: we have a partial order of structured spaces, and we are finding subsets of this partial order that can take each adjective, and then finding the maximum of the union, but because we're working on a partial order, a maximum might not exist -- we might just have a bunch of maximal elements). Luckily, in this case we don't need to worry about this problem... Anyway, compactness makes sense for topological spaces, which are very general. And convexity requires us to be able to add elements and scale them (since we need to form the expression for ). So maybe it's a topological vector space, but actually we don't need to be so general. I think we can just think of our space as being the subset of the Euclidean space . I'm not entirely confident though; the paper talks about "the space of all valuations ", so maybe that's supposed to be the ambient space.

For the fixed point reasoning: we don't actually have a fixed point of ; instead, it's a fixed point of , where and . If , then the graph of is just the graph of but shifted to the left. You will see that this intersects the graph of the identity function at ; this is the fixed point. On the other hand, if , then we shift the graph of to the right, and now the fixed point is at .

The key property of that we use in the proof:

  • If buys a share of on day , then the price of on day is 1 (the maximum possible).
  • If sells a share of on day , then the price of on day is 0 (the minimum possible).

One question to ask is, couldn't we just avoid using Brouwer's fixed point theorem by just setting the prices to obey the above property? There are two problems with this. One is that the definition of the th day prices would depend on 's behavior, which depends on the th day prices! So the definition would be circular. The other problem is that we can't guarantee that the map would be continuous if we just magically set it to obey some property.

Something else I got confused about: I was thinking that the above key property only talks about day . Couldn't the trader make a lot of money on previous days, and then just make no money on day , so that it would still be making lots of money? The answer is that we are only dealing with a trading strategy in this lemma, not a full trader. Later, in lemma 5.1.3, we recursively use this idea to deal with a full trader.

How do we come up with the definition of fix? Here's one way to think about it. Let be the market price (of some sentence on day ) and be the trading volume of that sentence on the same day. We want to return some quantity that fixes up the price, after the fact, so that the trader would have earned less money. Why after the fact? Because doing it in real time is confusing! The trader depends on the prices for day n, which is what we want to decide. But we want to know what the trader does on day n in order to determine the prices. So there is a circular dependency. This sort of thing happens in game theory too, where everything does eventually take place in real time, but we can think iteratively by "pressing pause" and considering counterfactuals and going down different paths in the game tree. Here is another way to think about it. We get an infinite number of "retries". We first set the price to something arbitrary. Then we get to see what the trader would do in that situation. Ah, it buys some shares, making money in expectation. We want to prevent that, so we pretend that wasn't the real market price, and see what the trader does in the new, adjusted price. It's also a hint that fixed points are going to appear. Ideally we would like to say something like:

This will work, but it's after the fact. We eventually would like to fix the prices in real time. So one way to think about this is to adjust the prices a little at a time, querying the trading strategy each time to see if we should nudge the prices up or down. Here is one idea:

where is some small adjustment. In other words, if a trader buys at the current price, then nudge it up a little to make it a slightly worse deal for the trader. And if the trader sells at the current price, then nudge it down. Now, there are three problems with this map. As a function of , it's still discontinuous (ugly). Also, we don't check whether the values we return stay within the allowed interval of valuations. But most importantly, if we only adjust the prices a little, that means the trader can still make money from us. So what can we do? Well, we can apply the map many times: (actually, maybe we should allow the s to change as well, to react in response). Now it's like a turn-based game: the trader says he's going to buy, so we adjust up; the trader still says he's buying, so we adjust up again; the trader now says he's going to sell, so we adjust down (oops, now we're in exactly the same spot, leading to an infinite loop...).

We can fix the second problem above with the following:

Now if the prices go out of bounds, they get adjusted back to the bound, but otherwise they are unaffected.

Let be a trading strategy that takes the price of a sentence and outputs how much it would trade at that price. So then we start with some price , which gets fed into to get . Then we have the next price . And the next trade volume is and so on. So we get .

So what can we do to avoid the infinite loop? One idea might be to decrease the step size with time (the number of iterations). This sort of thing is reminiscent of some versions of gradient descent. Another idea is to make the step size a function of : if the trader trades a lot, then we adjust a lot, but if the trader trades only a little, it signals that we're getting close to ... a fixed point!

This turns out to be equivalent to , which is the form of fix given in the paper. To see this, just split into cases based on , , or . The version in the paper makes it obvious that the function is continuous, but it is more difficult to see what is going on.

We want some such that , i.e. we are satisfied with the price so that we don't try to change it. Thanks to both being continuous, this is guaranteed by Brouwer's fixed point theorem.

We imagined that we were working with just one sentence, but it turns out that (for some reason) basically the same thing works when dealing with all sentences.

Another thing to wonder is that the rate of adjustment is just . What if we did instead? or ? or ? It seems like these would change the slope of the graph of , which means we might introduce more fixed points (just graph the identity function with the new functions); one of the nice things about slope=1 is that it is parallel to the identity function, so we get exactly one fixed point, or infinitely many. Actually, the scalar on x is still 1, so this probably doesn't matter.

The following is used in the Fixed Point Lemma (5.1.1):

Writing the -strategy as

we have

But so the two sums cancel to obtain .

I think here is a simpler way to do the summation at the end: Write as . Then we have

where the first equality follows from the linearity of , the second because , and the third because we can change the summation from to and by the definition of .

Definition/Proposition 5.1.2 (MarketMaker)

Define by (this is the same map given in the proof).

Let's see what does to . By the Fixed Point Lemma, for any we have . This means that as we max over these worlds, we will never exceed 0. So . Or in other words . (I had two confusions here: first, for some reason I mistakenly thought was negative for a while, so got confused about why was always contained in the interval. Second, I wondered why the left endpoint was minus infinity; couldn't any negative number also work? it couldn't, because we don't know how negative the trader could be; in other words, the trader could perform arbitrarily badly and we don't have a lower bound on that.)

What I'm not sure about is why we need to do this thing. Couldn't we fix some at the start, and consider the map ? Then by the same reasoning, for maps into so we have a neighborhood in that maps into this open set. It seems like we didn't need to form the max over all the worlds. Of course, doing this stuff becomes important when doing the brute force search later in the proof, but if we're merely trying to verify the pricing exists, it doesn't seem like we need to do this finite support stuff.

"Hence there is some neighborhood in around with image in ." -- This uses one of the equivalent definitions of continuity (often called the topological definition of continuity), namely, is continuous iff for every open set such that , there exists an open set such that and . Here we know that is open and . So there exists an open set such that and .

One thing I'm unclear on is, are we using a metric on ? If so, what is the metric?

Lemma 5.1.3 (MarketMaker Inexploitability)

This proof is pretty simple.

We use the geometric series . (Then subtract since index starts at 1 rather than 0.)

Definition/Proposition 5.2.1 (Budgeter)

Why does Budgeter get all of ? It seems to use only up to .

What's up with the then-clause? Does it even trigger? I think it's just there to make sure Budgeter is defined in all cases. The else-clause doesn't make sense for some values of .

Another question I had was why the budget is a positive integer, rather than a positive rational. After all, our markets run on rational prices. I think this is because in the way TradingFirm is constructed, all we care about is that we can increase the budget as much as we want, to let the good traders do what they want. The key property is Lemma 5.2.2.3. So basically we just need a subset of the rationals that is not bounded above. I think also works well because it's very easy to enumerate (maybe also it's important that it's easy to enumerate in increasing order).

For the inf expression in the else-clause: the fact that we're in the else-clause means that the "if" part is false, so for (which is less than ) in particular, the sum . So the denominator . Now suppose that according to , the trader wins money on day n. Then is negative, so that the whole fraction is negative. Thus the output of max is 1, so that Budgeter returns . In other words, if the trader is going to win money anyway, then Budgeter does not interfere with what the trader is doing.

But now suppose that according to , the trader loses money on day n. Thus is positive. As long as the amount of money lost is within the wealth of the trader (which is , the expression in the denominator), the fraction is at most 1, so max outputs 1. In other words, Budgeter does nothing because the trader "stays within budget". However, if the trader loses a lot of money on day n, so that it loses more than the wealth it has gained up to that point, then Budgeter kicks in. Suppose I have $10 and am about to lose $30. To stay within my budget I would have to spend at most $10, i.e. I would need to scale my spending by . The same idea applies to the case of Budgeter, where is the amount I would have spent ($30) and is the amount I actually have ($10). Why do we take the inf over possible worlds? Because we want to defend against the worst case scenario. Suppose I have $10 (for certain), but now Alice says I am about to lose $30 and Bob says I am about to lose $50. Now, I don't know which of Alice or Bob is right, but I know that at least one of them is right. In order to guarantee that I won't overspend, I must scale my spending by 10/50, because that is the more pessimistic of the scenarios: if Bob is right, then I lose $50 * (10/50) = $10, and if Alice is right I lose $30*(10/50) = $6, so in either case I stay within my budget. And indeed we have .

Lemma 5.2.2 (Properties of Budgeter)

Part 1

If the trader never overspends, then budgeter does nothing. The proof of this is basically the same as the reasoning in the previous section.

Part 2

If we inductively alter the trader on every single day, then we never overspend.

It seems like a simple inductive proof could work here, but instead we get a horrid thing. Actually it seems like the same proof.

"(since )" -- it took me a while to understand what they were doing here. What they're saying is that normally when you take off the "inf" and instantiate it to a specific thing in the class, the expression should go up but instead here it goes down, and the reason it does that is that the at the front of the expression is negative, so it reverses things. I had mistakenly been staring at the inside the max, so was confused about this.

Part 3

If the trader can exploit the market, then we can give it the budget it needs so that it can do its thing.

Proposition 5.3.1 (Redundant Enumeration of e.c. Traders)

I think the key point of this proof is that the in is the same as the in , so that the input to the trader computation (which says what day it is) controls how long the computation can run.

Suppose we tried skipping the enumeration of the polynomials. Given , we could decode it into a pair of integers , and run for steps. This would find all e.c. traders, but it would also find traders who aren't e.c., because the runtime isn't connected to the input to .

But given an -strategy, shouldn't we be able to tell whether it is e.c. or not?

Definition/Proposition 5.3.2 (TradingFirm)

Why do we want to blank out the traders by defining ? shouldn't giving the later traders less weight be sufficient? This assumption is used to make the sum into . In other words, on any day we are only dealing with a finite number of traders.

Lemma 5.3.3 (Trading Firm Dominance)

See also