Archive:
In this section: Subtopics:
Comments disabled |
Mon, 28 Feb 2022
Quicker and easier ways to get more light
Hacker News today is discussing this article by Lincoln Quirk about ways to get more light in your home office. Why?You might do this because you have trouble seeing. Or because you find you are more productive when the room is brighter. Or perhaps you have seasonal affective disorder, for which more light is a recognized treatment. For SAD you can buy these cute little light therapy boxes that are supposed to help, but they don't, because they are not bright enough to make a difference. Waste of money. Quirk's summaryQuirk says:
and describes some possible approaches. One is to buy 25 ordinary LED bulbs, and make some sort of contraption to mount them on the wall or ceiling. This is cheap, but you have to figure out how to mount the bulbs and then you have to do it. And you have to manage 25 bulbs, which might annoy you. Quirk points out that 815-lumen LED bulbs can be had for $1.93, for a cost of $2.75 / kilolumen (klm). Another suggestion of Quirk's is to use LED strips, but I think you'd have to figure out how to control them, and they are expensive: Quirk says $16 / klm. Here's what I did that was easy and relatively inexpensiveThis thing is a “corn bulb”, so-called because it is a long cylinder with many LEDs arranged on in like kernels on a corn cob. A single bulb fits into a standard light socket but delivers up to twelve times as much light as a standard bulb. You can buy them from the DragonLight company.
The fourth column is the corn bulb's luminance compared with a standard 100W incandescent bulb, which I think emits around 1600 lm. Cost varies from $7.33 / klm at the top of the table to $4.93 / klm at the bottom. I got an 80-watt corn bulb ($60) for my office. It is really bright, startlingly bright, too bright to look at directly. It was about a month before I got used to it and stopped saying “woah” every time I flipped the switch. I liked it so much I bought a 120-watt bulb for the other receptacle. I'd like to post a photo, but all you would be able to see is a splotch. The two bulbs cost around $140 total and jointly deliver 24,000 lumens, which is as much light as 15 or 16 bright incandescent bulbs, for $5.83 / klm. It's twice as expensive as the cheap solution but has the great benefit that I didn't have to think about it, it was as simple as putting new bulbs into the two sockets I already had. Also, as I said, I started with one $60 bulb to see whether I liked it. If you are interested in what it is like to have a much better-lit room, this is a low-risk and low-effort way to find out. Corn bulbs are available in different color temperatures. In my view the biggest drawback is that each bulb carries a cooling fan built into its base. The fan runs at 40–50 dB, and many people would find it disturbing. [Addendum 20220403: Fanless bulbs are now available. See below.] Lincoln Quirk says he didn't like the light quality; I like it just fine. The color is not adjustable, but if you have two separately-controllable sockets you could put a bulb of one color in each socket and switch between them. I found out about the corn bulbs from YOU NEED MORE LUMENS by David Chapman, and Your room can be as bright as the outdoors by Ben Kuhn. Thanks very much to Benjamin Esham for figuring this out for me; I had forgotten where I got the idea. [ Addendum 20220403: Gábor Lehel points out that DragonLight now sells fanless bulbs in all wattages. Apparently because the bulb housing is all-aluminum, the bulb can dissipate enough heat even without the fan. Thanks! ] [Other articles in category /tech] permanent link Sat, 26 Feb 2022
I vent my rage at dumbass Math SE comments
[ Content warning: ranting ] An article I've had in progress for a while is an essay about the dogmatic slogan that “infinity is not a number”. As research for that article I got Math Stack Exchange to disgorge all the comments that used that phrase. There were several dozen. Most of them were just inane, or ill-considered; some contained genuine technical errors. But this one was so annoying that I have paused to complain about it individually:
That is not “one thing”. It is three things. A person who is unclear on the distinction between 1 and 3 should withhold their opinions about the nature of infinity. [ Addendum 20220301: I did not clearly communicate which side of the “infinity is not a number” issue I am on. Here's my preliminary statement on the matter: The facile and prevalent claim that “infinity is not a number”, to the extent that it isn't inane, is false. I hope this is sufficiently clear. ] [Other articles in category /math/se] permanent link Thu, 24 Feb 2022
More about the axioms of infinity and the empty set
[ Content warning: inconclusive nattering ] Yesterday I discussed how one can remove the symbol ∅ from the statement of the axiom of infinity (“A∞”). Normally, A∞ looks like this: ∃S(∅∈S∧(∀x∈S)x∪{x}∈S). But the “∅” is just an abbreviation for “some set Z with the property ∀y.y∉Z”, so one should understand the statement above as shorthand for: ∃S((∃Z.(∀y.y∉Z)∧(Z∈S))∧(∀x∈S)x∪{x}∈S). (The ∪ and {x} signs should be expanded analogously, as abbreviations for longer formulas, but we will ignore them today.) Thinking on it a little more, I realized that you could conceivably get into big trouble by doing this, for a reason very much like the one that concerned me initially. Suppose that, in (♡), in place of ∃Z.(∀y.y∉Z)∧(Z∈S), we had ∃Z.(∀y.y∈Z⟺y∉y)∧(Z∈S). Now instead of Z having the empty-set property, it is required to have the Russell set property, and we demand that the infinite set S include an element with that property. But there is provably no such Z, which makes the axioms inconsistent. My request that ∅ be proved to exist before it be used in the construction of S was not entirely silly. My original objection partook of a few things:
I believe that expanding abbreviations as we did above addresses this issue adequately.
“Meaningful” is the wrong word here. I'm willing to agree that the defined symbol necessarily has a sense. But without an existence proof the symbol may not refer to anything. This is still a live issue, because if the symbol doesn't denote anything, your axiom has a big problem and ruins the whole theory. The axiom has a sense, but if it asserts the existence of some derived object, as this one does, the theory is inconsistent, and if it asserts the universality of some derived property, the theory is vacuous. I think embedding the existence claim inside another axiom, as is done in (♡), makes it easier to overlook the existence issue. Why use complicated axioms when you could use simpler ones? But technically this is not a big deal: if Z doesn't exist, then neither does S, and the axioms are inconsistent, regardless of whether we chose to embed the definition of Z in A∞ or leave it separate. One reason to prefer simpler axioms is that we hope it will be easier to detect that something is wrong with them. But set theorists do spend a lot of time thinking about the consistency of their theories, and understand the consistency issues much better than I do. If they think it's not a problem to embed the axiom of the empty set into A∞, who am I to disagree? [Other articles in category /math] permanent link Wed, 23 Feb 2022
My mistake about errors in the presentation of axiomatic set theory
[ Content warning: highly technical mathematics ] A couple of weeks ago I claimed:
Well, it sort of is and isn't at the same time. But the omission that bothered me is not really an error. The experts were right and I was mistaken. (Maybe I should repeat my disclaimer that I never thought there was a substantive error, just an error of presentation. Only a crackpot would reject the substance of ZF set theory, and I am not prepared to do that this week.) My argument was something like this:
I ended by saying:
Several people tried to explain my error, pointing out that ∅ is not part of the language of set theory, so the actual formal statement of A∞ doesn't include the ∅ symbol anyway. But I didn't understand the point until I read Eike Schulte's explanation. M. Schulte delved into the syntactic details of what we really mean by abbreviations like ∅, and why they are meaningful even before we prove that the abbreviation refers to something. Instead of explicitly mentioning ∅, which had bothered me, M. Schulte suggested this version of A∞: ∃S((∃Z.(∀y.y∉Z)∧(Z∈S))∧(∀x∈S)x∪{x}∈S). We don't have to say that S (the infinite set) includes ∅, which is subject to my quibble about ∅ not being meaningful. Instead we can just say that S includes some element Z that has the property ∀y.y∉Z; that is, it includes an element Z that happens to be empty. A couple of people had suggested something like this before M. Schulte did, but I either didn't understand or I felt this didn't contradict my original point. I thought:
In a conversation elsewhere, I said:
I found Schulte's explanation convincing though. The A∞ that Schulte suggested is not a mere conjunction of axioms. The usual form of A∞ states that the infinite set S must include ∅, whatever that means. The rewritten form has the same content, but more explicit: S must include some element Z that has the emptiness property (∀y.y∉Z) that we want ∅ to have. I am satisfied. I hereby recant the mistaken conclusion of that article. Thanks to everyone who helped me out with this: Ben Zinberg, Asaf Karagila, Nick Drozd, and especially to Eike Schulte. There are now only 14,823,901,417,522 things remaining that I don't know. Onward to zero! [ Addendum 20220224: A bit more about this. ] [Other articles in category /math] permanent link Tue, 22 Feb 2022
“Shall” and “will” strike back from beyond the grave
In former times and other dialects of English, there was a distinction between ‘shall’ and ‘will’. To explain the distinction correctly would require research, and I have a busy day today. Instead I will approximate it by saying that up to the middle of the 19th century, ‘shall’ referred to events that would happen in due course, whereas ‘will' was for events brought about intentionally, by force of will. An English child of the 1830's, stamping its foot and shouting “I will have another cookie”, was expressing its firm intention to get the cookie against all opposition. The same child shouting “I shall have another cookie” was making a prediction about the future that might or might not have turned out to be correct. In American English at least, this distinction is dead. In The American Language, H.L. Mencken wrote:
That was no later than 1937, and he had been observing the trend as early as the first edition (1919):
But yesterday, to my amazement, I found myself grappling with it! I had written:
To me, the “won't” connoted a willful refusal on the part of OP, in the sense of “I won't do it!”, and not what I wanted to express, which was an inevitable outcome. I'm not sure whether anyone else would have read it the same way, but I was happier after I rewrote it:
I could also gotten the meaning I wanted by replacing “can't and won't” with “can't and shan't” — except that “shan't’ is dead, I never use it, and, had I thought of it, I would have made a rude and contemptuous nose noise. Mencken says “the future in English is most commonly expressed by neither shall nor will, but by the must commoner contraction 'll’. In this case that wasn't true! I wonder if he missed the connotation of “won't” that I felt, or if the connotation arose after he wrote his book, or if it's just something idiosyncratic to me. [Other articles in category /lang] permanent link Mon, 21 Feb 2022
What to do if you're about to fail real analysis for the second time?
A few months ago a Reddit user came to
The first thing that came to mind for me was “wow, you're fucked”. There was a time in my life when I might have posted that reply but I'm a little more mature now and I know better. I read some of the replies. The top answer was a link to a pirated copy of Aksoy and Khamsi's A Problem Book in Real Analysis. A little too late for that, I think. Hapless OP must re-sit the exam in a few days and can't do the homework questions or practice papers; the answer isn't simply “more practice”, because there isn't time. The second-highest-voted reply was similar: “Pick up Stephen Abbott's Understanding Analysis”. Same. It's much too late for that. The third reply was fatuous: “understand the proofs done in the
textbook/lecture completely, since a lot of the techniques used to
prove those statements you will probably need to use while doing
problems”. Here's one I especially despised:
“Don't worry”! Don't worry about having to repeat the year? Don't worry about getting kicked out of university? I honestly think “wow, you're fucked” would be less damaging. In the book of notoriously ineffective problem-solving strategies, chapter 1 is titled “Pretend there is No Problem”. This was amusing but unhelpful:
(However, another user disagreed: “Compared to real analysis, death is nothing to fear”.) Some comments offered hints: focus on topology, try proof by contradiction. Too little, and much too late. Most of the practical suggestions, in my opinion, were answering the wrong question. They all started from the premise that it would be possible for Hapless OP to pass the exam. I see no evidence that this was the case. If Hapless OP had showed up on Reddit having failed the midterm, or even a few weeks ahead of the final, that would be a very different situation. There would still have been time to turn things around. OP could get tutoring. They could go to office hours regularly. They could organize a study group. They could work hard with one of those books that the other replies mentioned. But with “a few days” left? Not a chance. The problem to solve here isn't “how can OP pass the exam”. It's “how can OP deal with the inescapable fact that they cannot and will not pass the exam”. Way downthread there was some advice (from user tipf) that was gloomy but which, unlike the rest of the comments, engaged the real issue, that Hapless OP wasn't going to pass the exam the following week:
Pessimistic, yes, but unlike the other suggestions, it actually engages with Hapless OP's position as they described it (“have to resit the whole year (can't afford)”). When we reframe the question as “how can OP deal the fact that they won't pass the exam”, some new paths become available for exploration. I suggested:
For example, just hypothetically, what if the math department administrative assistant said:
This is not completely implausible, and if true might put Hapless OP in a much better position! Now you might say “Dominus, you just made that up as an example, there is no reason to think it is actually true.” And you would be quite correct. But we could make up fifty of these, and the chances would pretty good that one of them was actually true. The key is to find out which one. And OP can't find out what is available unless they go talk to someone in the math department. Certainly not by moping in their room reading Reddit. Every minute spent moping is time that could be better spent tracking down the Dean, or writing the letter, or filing the forms, or whatever might be required to improve the situation. Along the same lines, I suggested:
I don't know if Hapless OP would have been happy with a Statistics major; they didn't say. But again, the point is, there may be options that are more attractive than “get kicked out of uni”, and OP should go find out what they are. The higher-level advice here, which I think is generally good, is that while asking on Reddit is quick and easy, it's not likely to produce anything of value. It's like looking for your lost wallet under the lamppost because the light is good. But it doesn't work; you need to go ask the question to the people who actually know what the solutions might be and who are in a position to actually do something about the problem. [ Addendum 20220222: Still higher-level advice is: if you're losing the game, try instead playing the different game that is one level up. ] [Other articles in category /math] permanent link Fri, 11 Feb 2022
Geometric proof that the mediant lies between its arguments
The mediant of two fractions ab and cd is simply a+cb+d. It appears often in connection with the theory of continued fractions, and a couple of months ago I put it to use in this post about Newton's method. There the crucial property was that if ab<cd then ab<a+cb+d<cd. This can be proved with straightforward algebra: ab<cdad<bcab+ad<ab+bca(b+d)<(a+c)bab<a+cb+d and similarly for the cd side. But Reddit user asenseofbeauty recently suggested a lovely visual proof that makes the result intuitively clear: The idea is simply this: ab is the slope of the line from the origin O through the point P=⟨b,a⟩ (blue) and cd is the slope of the line through Q=⟨d,c⟩ (red). The point ⟨b+d,a+c⟩ is the fourth vertex of the parallelogram with vertices at O,P,Q, and a+cb+d is the slope of the parallelogram's diagonal. Since the diagonal lies between the two sides, the slope must also lie in the middle somewhere. The embedded display above should be interactive. You can drag around the red and blue points and watch the diagonal with slope a+bc+d slide around to match. In case the demo doesn't work, here's a screenshot showing that 25<2+45+3<43: [ Addendum 20220215: The source was this Reddit comment from asenseofbeauty. ] [Other articles in category /math] permanent link Wed, 09 Feb 2022
If I haven't replied to your email about Haskell…
This worked better than I expected. Someone posted it to Hacker News, and it reached #1. I got 45 emails with suggestions about where to apply, and some suggestions through other channels also. Many thanks to everyone who contributed. I'm answering the messages in the order I received them. Thoughtful replies take time. If I haven't answered yours yet, it's not that I am uninterested, or I am blowing you off. It's because I got 45 emails. Thanks for your patience and understanding. [Other articles in category /meta] permanent link Mon, 07 Feb 2022
I would like a job writing Haskell
Perhaps someone out there wants to take a chance on a senior programmer with thirty years of experience who wants to make a move into Haskell. I'm between jobs right now, having resigned my old one without having a new one lined up. It's been a pleasant vacation but it can't go on forever. At some point I'll need another job. I would really like it to be Haskell programming but I don't know where to look. I hope maybe one of my Gentle Readers does. I don't have any professional or substantial Haskell experience, but a Haskell shop might be happy to get me anyway. I think I'm well-prepared to rapidly get up to speed writing production Haskell programs:
If you're interested, or if you know someone who might be,
here's my résumé.
please feel free to pass it around or to ask me questions at
Thanks for your kind attention. Big restriction: I live in Philadelphia and cannot relocate. I have no objection to occasional travel, and a long history of sucessful remote work. [ Addendum 20220209: If you emailed me and haven't heard back, it's only because response was overwhelming and I haven't gotten to your message yet. Thank you! ] [Other articles in category /meta] permanent link Sun, 06 Feb 2022
A one-character omission caused my Python program to hang (not)
I just ran into a weird and annoying program behavior. I was
writing a Python program, and when I ran it, it seemed to hang.
Worried that it was stuck in some sort of resource-intensive loop I
interrupted it, and then I got what looked like an error message from
the interpreter. I tried this several more times, with the same
result; I tried putting The real problem was that the first line which said:
when it should have been:
Without that magic
which tells it to run the I didn't even know there was an I might have picked up on this sooner if I had actually looked at the error messages:
In particular, I don't remember making this mistake before but it seems like it would be an easy mistake to make. It might serve as a good example when explaining to nontechnical people how finicky and exacting programming can be. I think it wouldn't be hard to understand what happened. This computer stuff is amazingly complicated. I don't know how anyone gets anything done. [Other articles in category /Unix] permanent link Sat, 05 Feb 2022
Factoring composite numbers into nearly equal factors
Pennsylvania license plate numbers have four digits and when I'm driving I habitually try to factor these. (This hasn't yet led to any serious injury or property damage…) In general factoring is a hardish problem but when n<10000 the worst case is 9991=97·103 which is not out of reach. The toughest part is when you find a factor like 661 or 667 and have to decide if it is prime. For 667 you might notice right off that it is 676−9=(26+3)(26−3) but for 661 you have to wonder if maybe there is something like that and you just haven't thought of it yet. (There isn't.) A related problem is the Nearly Equal Factors (NEF) problem: given
n, find a and b, as close as possible, with ab=n. If
n has one large prime factor, as it often does, this is quite
easy. For example suppose we are driving on the Interstate and are
behind a car with license plate When I first started thinking about this I thought maybe there could be a divide-and-conquer algorithm. For example, suppose n=4m. Then if we could find an optimal ab=m, we could conclude that the optimal factorization of n would simply be n=2a·2b. Except no, that is completely wrong; a counterexample is n=20 where the optimal factorization is 5·4, not (2·5)·(2·1). So it's not that simple. It's tempting to conclude that NEF is NP-hard, because it does look a lot like Partition. In Partition someone hands you a list of numbers and demands to know of they can be divided into two piles with equal sums. This is NP-hard, and so the optimization version of it, where you are asked to produce two piles as nearly equal as possible, is at least as hard. The NEF problem seems similar: if you know the prime factors n=p1p2…pk then you can imagine that someone handed you the numbers logp1,…logpk and asked you to partition them into two nearly-equal piles. But this reduction is in the wrong direction; it only proves that Partition is at least as hard as NEF. Could there be a reduction in the other direction? I don't see anything obvious, but maybe there is something known about Partition or Knapsack that shows that even this restricted version is hard. [ Addendum: see below. ] In practice, the first-fit-decreasing (FFD) algorithm usually performs well for this sort of problem. In FFD we go through the prime factors in decreasing order, and throw each one into the bin that is least full. This always works when there is one large prime factor. For example with 6968 we throw the 67 into the a bin, then the 13 and two of the 2s into the b bin, at which point we have 67·52, so the final 2 goes into the b bin also, and this is optimal. FFD does find the optimal solution much of the time, but not always. It works for 20 but fails for 72=2332 because the first thing it does is to put the threes into separate bins. But the optimal solution 72=9·8 puts them in the same bin. Still it works for nearly all small numbers. I would like to look into whether FFD it produces optimal results almost all of the time, and if so how almost? Wikipedia seems to say that the corresponding FFD algorithm for Partition, called LPT-first scheduling is guaranteed to produce a larger total which is no more than 76 as big as the optimal, which would mean that for the NEF problem n=ab and a≥b it will produce an a value no more than OPT7/6 where OPT is the minimum possible a. Some small-number cases where FFD fails are: nFFD=abOptimallog(a)log(OPT)(≤1.167)7212·69·81.13118018·1015·121.06724020·1216·151.08028824·1218·161.10033628·1221·161.09454030·1827·201.032 I wrote code to compute these and then I lost it. I would also like to look at algorithms for NEF that don't begin by factoring n. We can guarantee to find optimal solutions with brute force, and in some cases this works very well. Consider 240 we begin by computing (in at most O(log2n) time) the integer square root of 240, which is 15. Then since 240 is a multiple of 15 we have 240=16·15 and we win. In general of course it is not so easy, and it fails even in some cases where n is easy to factor. n=p2k+1 is especially unfortunate. Say n=243 so the square root is 15, which is not a factor of 243. So we try 14, then 13,12,11,10 and at last we find 243=27·9. [ Addendum 20220207: Dan Brumleve points out that it is NP-complete to decide whether, given numbers L,U,N, there is a number f in [L,U] that divides N. Using this, he shows that it is probably NP-complete to decide whether a given N is a product of two integers with |a−b|≤N1/4. “Probably” here means that the reduction from Partition is polynomial time if Cramér's conjecture is correct. ] [Other articles in category /math] permanent link Today I learned that Julie Cypher, longtime partner of Melissa Etheridge, was actually born under the name Julie Cypher. Her dad's last name was Cypher, and it's apparently not even a very rare name. It happens pretty often that I run into names and say to myself “wow, I'm glad that's not my name”. Or even “that's a cool name, but not as cool as ‘Dominus’.” But ‘Cypher’ is as cool as ‘Dominus’. [ Addendum: I have mentioned before that Dominus is my birth name, not a recent invention. It came from Hungary, where it is in wider use than it is here. ] [ Addendum 20220315: Today's “wow, I'm glad that's not my name” moment was in connection with Patience D. Roggensack. If you were writing a novel and gave a character that name, people would complain you were being precious. ] [Other articles in category /misc/til] permanent link Fri, 04 Feb 2022
An unexpected turn of phrase from Robertson Davies
Dave Turner has been tinkering with a game he calls Semantle and this reminded me of Robertson Davies' novel What's Bred in the Bone, which includes a minor character named Charlie Fremantle. This is how my brain works. While I was looking up Charlie Fremantle I got sucked back into What's Bred in the Bone which is one of my favorite Davies novels. There is a long passage about Charlie and what he was like around 1933:
A Grail knight of social justice! A social justice warrior! And one of a subtype we easily recognize among us even today. Davies wrote that sentence in 1985. (But now that I look into it, I wonder what he meant to communicate by that phrase? In 1933, when that part of the book takes place, the phrase “social justice” was associated most closely with Father Charles Coughlin, founder of a political movement called the National Union for Social Justice, and publisher of the Social Justice periodical. Unlike Charlie, though, Coughlin was strongly anti-communist, which makes me wonder why Davies attached the phrase to him. Coincidence? I doubt that Davies was unaware of Coughlin in 1933, or had forgotten about him by 1985.) [ A reader asks if Davies, as a Canadian, would have been aware of Father Coughlin. I think probably. Wikipedia says Coughlin's radio show reached millions of people, perhaps as many as 30 million a week. The show was based in Detroit, so many of these listeners must have been Canadian. At that time Davies was a university student in Kingston, Ontario. Coughlin, incidentally, was also Canadian. ] [Other articles in category /book] permanent link Thu, 03 Feb 2022Driving around today I passed by Mosaic Community Church. I first understood “mosaic” in the sense of colored tiles, but shortly after realized it is probably “Mosaic” (that is, pertaining to Moses) and not “mosaic”. But maybe not, perhaps it is an intentional double meaning, with “mosaic” meant to suggest a diverse congregation. This got me thinking about words that completely change meaning when you capitalize them. The word “polish” came to mind. I wondered if there were any other examples and realized there must be a great many boring ones of a certain type, which I confirmed when I got home: Pennsylvania has towns named Perry, Auburn, Potter, Bath, and so on. I think what makes “Polish” and “Mosaic” more interesting may be that their meanings are not proper nouns themselves but are derived adjectives. [Other articles in category /lang] permanent link |