| rlucas.net | |||||||||||||||||||||||||||||||
|
Categories
Alternate Views
|
Tue, 26 Aug 2008
Fixing Net::Google error with 404 File does not exist
I was trying to install Net::Google 1.0 using CPANPLUS on my Mac OS X 10.5 machine, and kept getting a pesky error: Service description 'file:' can't be loaded: 404 File `' does not exist One thing I had to do to fix it was install an apparent prerequisite, SOAP::WSDL. It wasn't included by CPANPLUS. Another thing I had to do to make the tests run was to include the lib/ (not just the blib/) directory in @INC when running the tests: perl -Iblib/lib -Ilib t/001-search.t Even though that made the tests succeed, the installed module still wouldn't work and gave the same darn error. It turns out that some deeply, deeply nested code in Net::Google searches through @INC to find: $DIR/Net/Google/Services/GoogleSearch.wsdl This file doesn't get installed by "make install", unfortunately. So, I had to do the following: rlucas:/Library/Perl/5.8.8/Net/Google$ sudo mkdir Services Password: rlucas:/Library/Perl/5.8.8/Net/Google$ cd Services/ rlucas:/Library/Perl/5.8.8/Net/Google/Services$ sudo cp \ ~/.cpanplus/5.8.8/build/Net-Google-1.0/lib/Net/Google/Services/GoogleSearch.wsdl \ . Now my Net::Google using scripts seem to work right. $Id: net_google_wsdl_file.txt 1127 2008-08-27 02:11:49Z rlucas $ [category: /bugfix] [permalink] Tue, 22 Jan 2008
Thoughts on the Eve of CFA I Results
On 01 December 2007, I took the CFA Level I exam. The results for this exam will be made available tomorrow (23 January 2008), but before I find out how I did, I think it might be useful to you and a good exercise for me to describe my thoughts on the exam, the process, and my self-assessment of how I did. First, a word of background. I am untrained in finance and economics in any formal sense. On the job as a venture capital analyst and associate for the past two years, I have learned modeling and DCF, and have also picked up a strong interest in reading macroeconomic blogs and news (e.g. The Economist, Calculated Risk). However, VC is not a "finance-heavy" branch of finance, as most of the risk we look to assess is more human and "soft" in nature, such as management and market risk. I never took economics, finance, or economics in school, although I did run bookkeeping for a couple of startup companies I ran (accrual accounting, double-entry bookkeeping). So the content of CFA I was largely new to me, though the generalities of finance were not. In general, I am very smart and a good test-taker. For example, I aced the SATs (on my second try), several College Board and AP exams, and most of my International Baccalaureate exams. But I studied like a mofo for those, and those (roughly 11 years ago) were the last time I took any standardized tests. In college, my record was significantly less stellar (for too many reasons to list here). However, CFA I claims you need 250 hours of prep. It boasts a 40% pass rate. Nearly all of the takers (so far as I can tell) come from the finance industry and/or economics or finance academic backgrounds. So I figured (then and now) that it's anyone's game: me, the solid test-taker, against CFA I, the exam whose pride depends upon trouncing 60% of comers despite their being specialists. So, I set out in June / July 2007 to begin studying for CFA I. I bought both the "official" curriculum (several hundred $$), about 12" thick of books, and the "Schweser" third-party, "Cliff's Notes"-style curriculum, which was perhaps 7" or 8" thick. I started out powering through the CFA books, but quickly, upon advice of friends and upon realizing the difference in concision, switched to using the Schweser exclusively. I got busy with a lot of work stuff and really didn't put much, if any, time into test prep in July-September 2007. Maybe 1 hour a week. Then, in October, I really picked things up, and started putting in 4-5 hours a week. Finally, in November, I rededicated myself to the effort, making flash cards, carrying books with me to lunch each day, and adopting a mantra of "study every day, test (practice tests) every weekend." I probably did an average of 15 hours per week during November 2007, starting at 10 hours and moving to 20 hours for the last couple weeks (2 hours a day for 6 days + 8 hours on Saturday). All in all, I'd estimate time spent: Nov 2007 4.3 weeks @ 15 hrs / week = 64.5 Oct 2007 4.3 weeks @ 5 hrs / week = 21.5 July-Sept 2007 13 weeks @ 1 hrs / week = 13 --- Total = 99 hrs In the last two weeks, I was scoring between 68% and 78% on the Schweser practice exams. (Two runs closer to 68%, the final "outlier" being closer to 78%.) Part of this may have been a discrepancy in the difficulty between the Schweser "sample" vs. "practice" exams; I think that the "practice" exams may be a bit harder to make the "sample" ones, and the real thing, seem easier. On exam day, I showed up with a good amount of fresh fruits, complex carbos, caffeine and nicotine, and lots of fresh pencils and two TI BA-II+ calculators. I did not get a good night's sleep before; much of that was probably stress (both CFA I and exogenous, career- and personal-oriented stress). On the morning half, I finished the exam once through with about an hour left to spare. I spent 35-40 minutes going over my answers and changed perhaps 10% of my answers from their prior values. (You're stuck in the room for the final 30 minutes if you haven't bailed before then; I napped at my desk.) On the afternoon half, I finished with just over an hour left. I reviewed my answers and changed maybe 5% of the values, but realized that I was "bonking" -- getting somewhat tired and low-blood-sugar, I was in danger of making corrections worse than the originals. So I called it with 45 minutes left, and drove home to Seattle through an incipient snowstorm to party it up with some old friends (including a CFA II candidate). Overall, I left the exam center confident that I did at least as well on the exams as I had on my practice / sample runs. Given what folks had been posting on Analyst Forum, I think high 60s would probably be a safe pass. Considering that my low-end practice runs were already there, and that I left feeling I did at least that well, I would wager, perhaps laying 4:1, that I passed. The one area I have some serious apprehension about would be with respect to the particulars of filling in the bubbles. Perhaps it was my 11 year hiatus, but in the afternoon session I recalled filling in some bubbles or such (not answers, just pro forma stuff) that I didn't remember from the morning. I'm hoping that it was a false memory, a true difference in the AM / PM test forms, or something not tabulated for scoring. But given the anal nature of standardized tests, who knows. Also, there were some rocky sections in the vagaries of financial statement analysis (there are lots of traps and tricks with e.g lease capitalization and LIFO COGS) and ethics. Bad showings in those two areas could have really knocked me down a few notches, perhaps enough to fail. So, there you have it: the story of one man's CFA I attempt. Will my superior test-taking history compensate for only having done 40% of the recommended hours of study? Will my senile old-man's mistake of filling in the wrong test center number or such disqualify my entire AM session? And will those whippersnappers with their recent finance degrees outfox me, leaving me in the dust? Stay tuned. (I promised myself a new motorcycle if I passed, so if you do stay tuned, you may get to hear another "product review" in short order...) Update: I passed. Multiple Choice Q# Topic Max Pts <=50% 51%-70% >70% - Alternative Assets 12 - * - - Derivatives 12 - * - - Economics 24 - - * - Equity Analysis 24 - - * - Ethical & Professional Stnds. 36 - - * - Financial Statement Analysis 68 - - * - Fixed Income Analysis 24 - - * - General Portfolio Management 12 - - * - Quantitative Analysis 28 - - * Thanks to the CFA Society of Seattle for a scholarship and to Voyager Capital for picking up expenses. $Id: thoughts_on_cfa_i_results_eve.txt 1061 2008-01-23 18:26:44Z rlucas $ [category: /finance] [permalink] Mon, 21 Jan 2008
Things Pictured on "The Stuff of Thought"
Here is an attempt at an exhaustive list of objects drawn as colorful icons on the cover of the hardcover 2007 edition of Steven Pinker's "The Stuff of Thought."
I think (from the first hundred pages) that each of these items is referenced at some point within the text. But how interesting that the only two items that Steve-o repeats are a straitjacket and a cigarette or joint. [category: /frivolity] [permalink] Thu, 10 Jan 2008
Against Blogging, or Why I Am Discontinuing This Futility
1. An experiment in radical openness. I started blogging in 2002/2003 as a way to post bug fixes that I'd discovered up onto the Web in a way that I and others could quickly find them. For example, if I got an "Parse Error #123 in dorklib.so," and I found out how to fix it, I'd post up both the error message and the fix so that anyone searching on the error message would find the fix right away. That worked really well for that limited purpose. I didn't get a lot of traffic, but I did get a decent amount, and folks tended to leave positive comments. I wasn't influencing crowds, but I was improving a few people's lives each week at no marginal cost to me. Karma bonus. Bloghisattva. Then, right after coming to work for Voyager Capital in late 2005, Web 2.0 and the social web were really taking off. I got the news, and decided I needed to really dive into the culture of "radical openness." Sort of getting on board with the MySpace generation (I'm a few months away from actually being a member -- rather, I'm the youngest possible "Gen Xer"). The idea is pretty simple: dive into the conversation, push your ideas and your self and your self-image out there. Privacy is old school, promiscuity is the new fad. I covered this in "Your Old-Ass Values Are Broken." It seems to work well for some people. Fred Wilson, a well known VC, has lots of readers for his cartoons of gay jokes, tales of how much he plays video games, and posts saying things like "fuck Apple". Decorum, farewell! You have been relegated to the recycle bin of history! When Real Grownups, like Fred Wilson, do the high-personality, low-filter thing, you end up with something like an unvarnished truth: lots of input, fairly low signal to noise ratio, and occasional obscenity or flagrancy -- but in exchange, you get a measure of honesty, a personal "voice" that engages the reader, and an (imagined) human connection with the writer. So, as I stated in "Plan Less, Write More", I decided to do less -- a lot less -- planning, filtering, and proofreading, and just let it hang out. Hey Fred, wait up, I'm hoppin' on board too! But, there are a couple of problems with that idea. 2. I rant too much when I'm radically open. The main problem is pretty reducible to an abstract model. Fred writes pretty much every day. So do most of the 20 or so bloggers I regularly read -- generally, at least a couple entries a week. At that rate, most of the entries end up being pretty tame and moderately well thought-out, even though they have this "unvarnished" quality. But I've been blogging once or twice a month on average. Why do I blog so much less than a real "blogger?" Well, because it hasn't been a priority for me. So, my entries tend to happen when I get particularly worked up about sharing something with the world -- in chemistry terms, I have a high "activation energy" for putting out a blog post, and so I only post when I'm agitated. The effect of this, of course, is that I seem to rant a lot. If I've come up with a novel observation on the VC industry, or a new tech trend I think is interesting, but I'm not worked up over it, I probably won't write about it. But if I'm having a shitty day, and some software bug or ill-considered policy really tweaks me off, then bang, I settle up the bill with an excoriating blog rant faster than you can say "Fred's your uncle." (Sometimes, happily, I think better of it before pushing the post out to the Web, but often not.) So, I end up with a strong bias toward rants. Probably not the best. 3. Domain blogging would be good. What could fix this? Well, "domain blogging" is one possibility, where I create a single blog based on one topic and really hammer on it. (I've tried vainly to separate things into categories here but they end up pretty spread out with no critical mass in any one.) The problem with domain blogging in my main domain of activity -- venture capital finance of early stage tech companies -- is that the best and meatiest observation and analysis of the industry is the worst possible thing you can put into a public blog. My job is all about relationship, resource, and information asymmetry. We make it our job, eight days a week, to cultivate relationships with the right people, to raise funds for our discretionary deployment, and to form proprietary opinions on market and technology trends. Then, we go around trading and arbitraging these things, like for like, and for equity in a startup, and eventually for dollars returned to our investors. So, the meatiest things I could post here would be about those relationships, or resources, or that information. Which, of course, is like laying out a dish of dollars for all your competitors to see. Within the world of VC, my situation is generalizable, but not universal. Back to our exemplar par excellence (sorry, Fred), there actually are some circumstances in which radical openness within the domain is a successful strategy. If you can, leveraging the Web, get a dominant mindshare among the wired crowd by means of your openness, you might cast a much larger shadow than you really have, and actually attract to yourself valuable relationships, resources, and info. But it's a fat-tail game even within the fat-tail industry of VC, and it's risky: it's like shooting the moon in Hearts. Or like chopping blocks of ice with your hand. If you break through, you're golden! But if you don't, you've only managed to harm yourself in the process. It's probably OK for me to keep posting observations on the quirks of the industry, or purely functional / mechanical advice for newcomers, like my "VC Jargon" post. 4. Don't shit where you eat. There's another issue with domain blogging, too. The more senior, and more independent, the VC blogger, the more he can get away with. Junior executives of any stripe remain, in certain ways, beholden to the norms of their seniors. (I touched on this in "VCs and the Naughty Bits.") Even a completely independent entrepreneur, unless he wants forever to bootstrap or self-fund, can't stray too far from the comfort zone of his investors while in the public eye. (Nobody's smacked me down for this yet, but at this rate it's only a matter of time until I piss off the wrong person.) I used to think that, amongst the giants of this industry, I was like a court jester -- free to say whatever I thought, or whatever might seem funny or entertaining, even if it involved the king. How could the king get upset at a mere jester? A few events I've been to recently have changed my mind. Do you really want to be introduced over cocktails to someone whom you've accused (even indirectly) of having the skill set of a "retarded chimpanzee?" Yeah, me neither. Seattle's a small town, but guess what? Silicon Valley's a small valley (sic), NYC's a small metropolis -- in fact, it turns out it is a small damn world, after all. The chances of me sitting next to any given F50 CEO, Senator, Rails core developer, or hedge fund manager are individually pretty small, but OR'ed together and over a few years, end up approaching p=1. Might not want to badmouth too much (even if it is sort of in good humor and mostly about the issues, not the people). (Note that it does not escape me that this is one of the self-reinforcing traits of capitalism: every step up the ladder of wealth and influence that one takes is simultaneously a greater investment in the same system and a deeper barb into one's flesh. One is less and less able to speak truth to power the higher one gets; gotta keep one's reputation for playing a good clean game. Want to silence those upstart rabble-rousers? No need for a hit man; just give 'em promotions and fat raises.) 5. The problem with Steely Dan. Blogs are ostensibly written for the outside world to read. The author is dying to be a star, and make them laugh, right? But we all know that really, blogs are written for the writer to write. The further out the long tail the blog is, the truer this is, until N(readers) approaches 1, the author himself. At the peak, I had just over a thousand uniques monthly to the blog (most were RSS readers). Yay! Even I can't go visit my own blog from a thousand different cybercafes each month, so there must have been some actual readers. But let's make no mistake: I was getting no material (in either sense) benefit from my readership, so we can pretty much assume I was writing just for moi. And so, predictably, I indulged myself with things like addressing the "gentle reader" and making gratuitous references to Steely Dan or Beatles lyrics. This alone isn't a huge problem, but it doesn't exactly help mitigate the other issues. ("Hey, this VC associate just said my developers must have ordered extra lead paint chips on their breakfast cereal before coding the UI for my product, but then he threw in a line from 'Pretzel Logic' in the same post. Maybe he's not so bad after all!") Jackass allusions are fun easter eggs when a co-conspirator spots them, but they just confuse everyone else and make them think you're off-kilter. 6. Technical commentary is still appropriate. Technical commentary, including bug fixes and product reviews, are still very much appropriate. I think that using adult language is still probably OK, too, although after reading the now-infamous Zed's commentary on Rails I am rethinking just how cool it actually is to use the potty-mouth when talking about software. 7. Conclusion and next steps. Sadly, this means I will be stripping most of the humanity and voice from the blog. Which is OK since, frankly, the "radically open ranting voice" wasn't the best version of my voice anyhow. It also means I'm going to back and strike all the "big red words" from this little blog, or at least the most rant-a-licious parts. Sure, they'll still be cached somewhere, so an amateur historian of the inconsequential could still see just how indiscreet I once was. But this isn't about revoking or burying what once I said, but merely taking it off display, thus failing to renew implicitly my imprimatur. And so now, gentle reader, this author as you have known him must say adieu. Not radically closed, quite, but back to the paleo-openness of Web 1.0 goes this blog. $Id: against_blogging.txt 1069 2008-03-12 17:52:35Z rlucas $ [category: /metablog] [permalink] Mon, 12 Nov 2007
Entering a Hard Line Break in a Text Cell in Excel 2004 for Mac OS X
No cutesy commentary for once: The equivalent on Mac OS X of alt-enter for entering a hard line break within a cell in Excel is command-control-enter (open apple-control-enter). $Id: excel_mac_os_x_line_break.txt 1025 2007-11-13 04:11:18Z rlucas $ [category: /bugfix] [permalink] Thu, 01 Nov 2007
Microsoft: Clueless or Actively Hostile to Search?
I know that large enterprises have traditionally taken a lot longer to get clues, both generally, and specifically around search. To some extent, this is just a factor of organizational size: Voyager's awesomely successful enterprise search marketing company, SEMDirector, is helping enterprises learn to adapt to this brave new world, and creating a lot of value doing it. Of all big enterprises, Microsoft is one that we'd expect to be relatively early on the search bandwagon. After all, they've largely reoriented the company around search and advertising. But inexplicably, the very best assets that Microsoft has from a search-marketing content perspective -- the gigs and gigs of support info and (heh) bug workarounds on their massive, persistent, ubiquitous installed base -- are piss-poorly optimized for search! Sometime, try searching for something like, oh, say: exchange server pop mail marked as read ...which you might do if, like me, you're frustrated that MSFT's latest version of Exchange server can't seem to support POP3 access without flagging all the POP'ed messaged as read (thereby screwing up the flawed but de facto organizational method that Outlook has trained us all to use over the years). (Yes, it's a real problem; no, I haven't found a solution.) Well, the first several hits are forums, blogs, and ISV's offering solutions. Somewhere around 9th place comes a hit from Microsoft, though, and you're thinking: "Great! these forum postings are people complaining, but the solution will just be right here in the handy Microsoft link! Boy, what smart guys they are!" So you click on Microsoft Office Outlook 2003 Solution Center ... ...and what you get back is a huge page full of what I can only describe as "useless crap". Twenty or thirty topics, all loosely grouped around a product, but nothing apparently on my problem. A confusing mess of acronyms and key terms. Sigh. OK, So then you pull out the backup. Use your browser's in-page-search (cmd-f) to find "POP." Surely, one of these thirty topics is about what I want, I just need to find it here. (Though, isn't that what the search engine was supposed to have done? Whatever.) Search: "POP." A few instances, but nothing relevant. OK, Search: "marked as read." One instance, but describes the opposite of my problem. How about "marked as unread." Also irrelevant. Now you sit back and scratch your head: Every single other link in Google, prior to the Microsoft link, was relevant (if not useful) to my particular problem and my carefully worded query. Now comes the link from the very author of my misery, the Leviathan, and NOT A SINGLE G.D. SENTENCE is relevant to my problem!! And that's when it hit me: Microsoft's "support" pages are actually search engine spam. (And Google has properly detected this: that's why for Microsoft's own product, and despite Microsoft's huge "Google Juice," its own support pages rank a pitiful 9th.) The answer to what needs to be done is fairly simple. (Our friends at SEMDirector could walk you through it.) Push the search engine juice out to the edges of the graph (leaf nodes with real info, rather than these pseudo-indices which serve only to conflate keywords together that don't belong on the same page); let real human end-users discuss topics, using words that come naturally to them (and hence to other help-seekers); engage external bloggers and forums both to push info out into the ecosystem and to get deep links back in to the leaf nodes. (Back in 2004, I was seeing this kind of search-friendly behavior on HP's server support forums, and it was AWESOME. But then, that was all about running Linux on a well-engineered, open platform.) All of the above recommendations are anti-hierarchical, control-ceding, conversation-seeding moves. They require a mental move from hold on tightly to let go lightly. I'm talking about not just opening the kimono, but playing volleyball on the nude beach. Do you think that a company unable to do that with its support pages is going to be able to embrace a whole new and orthogonal, search-and-ads based strategy? $Id: msft_clueless_or_actively_hostile.txt 1051 2008-01-11 05:17:26Z rlucas $ [category: /tech_and_market_reflections] [permalink] Thu, 04 Oct 2007
wxPerl on Mac OS X must be run with special binary
If you are having trouble with your "hello world" wxPerl script on Mac OS X, check your shebang (#!) line and make sure you're running /usr/bin/wxPerl (or which ever wxPerl you have) rather than merely /usr/bin/perl -- the normal perl will display the main window but won't allow interaction between the window and the interface (e.g. you can see hello world but can't click the button). This posting seems to imply that Mac OS X 10.4 comes with a wxPerl installed; you can also get it via cpan / cpanp or from the wxPerl website if you don't have it on your Mac. $Id: wxperl_mac_os_x_must_use_special_binary.txt 997 2007-10-04 16:52:41Z rlucas $ [category: /bugfix] [permalink] Wed, 12 Sep 2007
Everything Old Is New Again: Innovation to Adoption Lag
There are a lot of problems in software that aren't solved well in a ubiquitous product (think PIMs, Personal Information Managers; they all suck royally despite everybody's best efforts, and the OSAF Chandler project has taken years trying to redesign the very concept, with little to show for it to date). But there are precious few problems that haven't been solved at all. In fact, a ton of things that are being held up these days as "innovations" are rehashes of old concepts from the 90s, or the 80s, or sometimes even the 70s. Today this came into sharp focus when I saw this bit from a circa 1999 document on the Semantic Web by the Right Reverend Tim Berners-Lee. Here he asks, then answers, a question: <blockquote> Surely all first-order or higher-order predicate caluculus based systems (such as KIF) have failed historically to have wide impact? The same was true of hypertext systems between 1970 and 1990, ie before the Web. Indeed, the same objection was raised to the Web, and the same reasons apply for pressing on with the dream. </blockquote> Then, while searching for some theory on append-only databases (such as would be used in a revision-control system), I came across this 1994 piece on "collaborative filtering." That report in turn points to earlier work on "Information Tapestry" from the early 1990s. So: 1970-1990, hypertext exists and is studied in CS departments. 1995, Netscape IPO. Early 1990s, collaborative filtering exists and is studied in research labs. 2006-2007, rise of Digg and Delicious. I think there's a very strong case to be made that VCs should stop looking for "innovation," per se, and start looking for 10-20 year old CS masters' theses that touch on an emerging market space... $Id: everything_old_is_new_again.txt 986 2007-09-13 00:57:24Z rlucas $ [category: /tech_and_market_reflections] [permalink] Thu, 06 Sep 2007
The Magical Coefficient of Motorcycling
There are a few things in Nature that seem like magical numbers. One is /e/. Another is the Golden Ratio. Another more applied version is 4 degrees C, the temperature at which water has its maximum density (thereby guaranteeing the action of thermal inversion, which prevents all of life from going extinct every few thousand years during an Ice Age). There's one for the world of motorcycling as well. But it's more boring if I just tell you want it is, so here's a bit of setup: Think about flying down the freeway at 60 or 70 MPH. Sure, you are ATGATT (all the gear, all the time -- no skin below the chin) and are helmeted, but doesn't it seem crazy not to wear a seatbelt or something? (This sentiment dates me as being of the generation that grew up with mandatory seatbelt laws.) How the hell can you hold on to something going 70 MPH? Well, it's only sort of crazy. It turns out that holding on to (or rather, not falling off of) something going 70 MPH is a damn sight easier when you're going 70 MPH along the same vector. What really matters is the acceleration involved. You at 0 MPH, bike at 70 MPH = bad news; you and bike both at 70 MPH = OK. But, you may counter, how the heck can you get to 70 MPH? Isn't that quite an acceleration, one that we usually encounter while strapped in with our backs against a DOT-approved seat? Well, yes. But your acceleration is really bounded by one thing: the friction of your tires on the pavement. (You can have a stronger engine or tighter brakes, but they only are effective to the limit of your tires' grip.) As it turns out, the natural properties of rubber make it so that you get about 1.1 g of traction on dry pavement. Torque your wheel faster, you spin out (or slow it more than that, you'l skid). Hence, as long as the bike isn't cheating -- starting or stopping using something besides the tires (like a rocket JATO or a brick wall) -- you're basically limited to applying about 1.0 g. And guess what? Human bodies and minds happen to be really good at dealing with 1.0 g. In fact, you might say that the whole of bipedalism is just drill for how not to tumble against the pull of 1.0 g. So, from the day you first pulled yourself up as an infant, you were practicing the skill needed to hang onto the handlebars during a 1.0 g acceleration. And that, my friends, is the magical coefficient of motorcycling: the traction of rubber on dry pavement. And that is why it's maybe not so crazy to go 70 MPH without a seatbelt after all. (Pace, engineers: I know that my explanation is oversimplified, but it's roughly right.) (And to the safety-concerned: your biggest concerns, of course, are exogenous to the question of traction: it's when you do hit a brick wall, or when you start testing the friction of leather on pavement, that you really get hurt.) $Id: the_magical_coefficient_of_motorcycyling.txt 1123 2008-07-28 03:13:38Z rlucas $ Thu, 30 Aug 2007
Bubble Factors: Real Change, Easy Credit, and Self-Interested Lies
Look at "Bubble 1.0" (as it's known in the relatively young tech industry: the 1997-2000 tech-media-telecom bubble and the general IPO / equity bubble that went along with it). 1. A real change occurred -- the uptake of Internet technology -- and created some initial successes (think Netscape IPO). This got folks thinking about how to turn a profit, lighting aflame the animal spirits, and buoyed the mood of the markets. 2. Accommodative monetary policy made money cheap, and in combination with the buoyant mood and the animal spirits, led to compressed risk premia in the capital markets. Think insatiable demand for IPOs, and Fed rate-slashing due to LTCM in 1998. 3. Sensing opportunity (and driven to madness by their proximity to money with no ability to make it themselves), those in charge of telling the truth, like auditors, started fudging things in order to keep the good times rolling and to get a slice o' Cheddar for themselves. Think Arthur Andersen and Enron. Now, let's take a look at Housing in 2002-2007. 1. A real change occurred. Think a palpable change in national mood and priorities post-bubble and post-9/11. In the realm of personal finance, we saw an aversion to "paper" assets and a move toward the real and tangible. To many people, this meant plowing what was left from equities into real estate, which had already been enjoying decent returns from the wealth effect of Bubble 1.0. 2. Accommodative credit. Think not only macro level, Fed funds rate stuff, but no-doc loans, NINJA (no income, no job or assets) loans, ARMs, option ARMs, interest-only loans, etc. 3. The truth-tellers started lying. Think the house appraisers here who were being incentivized to keep the party going at risk of losing business from the real estate agents, and the mortgage "officers" who were effectively the "buyer apraisers," incentivized to keep the party going directly due to fee structures. Nobody in either group called foul on the prices or the creditworthiness in question. This formula works pretty good, although it's loose enough that its predictive power is probably fairly weak (better for validating a thesis than for scouting out a new bubble in progress). Any other ideas as to bubbles where we can look for these factors? $Id: bubble_factors_change_credit_lies.txt 978 2007-08-30 22:42:36Z rlucas $ [category: /finance] [permalink] Tue, 14 Aug 2007 Option+PgDn Page down while moving cursor (caret) Esc Autocomplete Command+/ Comment/Uncomment (Ruby, at least) Ctrl+Command+V Paste without reindenting $Id: textmate 973 2007-08-15 00:56:21Z rlucas $ [category: /cheatsheets] [permalink] Thu, 09 Aug 2007 I spotted a piece by Paul Kedrosky today during a blog-feeds-catchup-session where Paul talks about a sort of "(minimum) two degree of separation" rule that VCs maintain between themselves and the sex industry. (Quotes above for my words, not his.) In other words: benefiting from infrastructure, transport, payment mechanisms -- cool. Having fleshy bits linked to from the portfolio companies page -- not cool. This reminds me of an early experience I had at Voyager. We were looking at a company that was building an online search / social media app. They talked about people using it for various applications -- consumer, enterprise, small business, blah blah blah. We were just about to the end of the pitch, when I asked pretty straightforwardly: "So, what's the sex angle here? Is there an application in dating or porn?" The room went silent. I pushed on, oblivious to the mood that had just chilled like a shot of Jaeger down an ice luge. "You know, like VHS, or modems for BBSes, or early adoption of Web marketing tricks like affiliate programs and popups," I articulated despite the intrusion of my foot now rapidly entering my oral cavity. "Is there a strategy for accelerating adoption around that content?" The founders were visibly uncomfortable. Mercifully, my boss was not pissed, just bemused. "I ... I guess people could use it for other things, too," said one of the founders, finally. Handshakes all around, a quick note on our investment process, and we'll get back to you after next week's partner meeting, ciao for now. Oops. Back at the office, this is addressed. "Randall, in the venture business, we have certain things we don't talk about, and certain things we don't invest in, due to a number of reasons." At the time, I'm thinking: OK, VCs are pillars of the community, have to show up at the Opera, at the charity events, at the B-school reunions, and can't be branded pornographer or such. I filed this away under the "shit not to talk about, Einstein" filter, along with ever admitting to listening to Journey, or denigrating tattoos while speaking to anyone whom you've never seen fully naked. But now, Paul Kedrosky gives me a flashback and with a key piece of insight. It's a follow the money moment: "... until the venture business is funded by groups other than pension funds, trusts, and endowments (ahem), the likelihood of mainstream VCs ever getting beyond flirtations [[with the sex business]] is vanishingly small." Yep, follow the money. The paymasters here are the Prudent Men, the real stodgy guys, the Trustees and the Chairmen and the Stewards and the Overseers. And frankly, this is probably a good thing. It's a little like the Senate. You don't want the country entirely run by a bunch of pasty old white dudes, most all millionaires, 60 years old and who won't be fired for 12 years (on average), and who probably still think that Kudzu and the missile gap are our biggest national problems. But you don't want a bunch of whippersnappers on the make driving all your big decisions without recourse to the accumulated wisdom of years past. The real test will be if one of the trendsetter endowment funds like Harvard or Yale green lights a VC or PE investment that targets the sin sectors. If that ever happens, then the VC business will start to get a lot more (directly) involved in the naughty bits... $Id: vcs_and_the_naughty_bits.txt 969 2007-08-09 18:19:32Z rlucas $ Wed, 08 Aug 2007
Liquidation Preferences: A Response to Leo Dirac
In a recent blog entry, Leo Parker Dirac poses the question of the fairness of liquidation preferences in VC financings of startups. He's going to be delivering a lightning talk based on it tonight at Ignite Seattle. (To those of you who don't know, liquidation preferences, or prefs, are usually a multiple of invested dollars that a VC gets out first, before anyone else is paid. This is because if you take $10 M from a VC for half your company, then shut down the company one second after depositing the VC's check, he would only have a claim on half of it, thereby snookering him out of $5 M. To avoid this outcome, and due to our general greed, we VCs like to ask for at least a 1.0x preference, meaning that you have no incentive to shut down the company until you've grown it to something more than our investment dollars.) His conclusion seems to be that liq prefs can be fair if transparently communicated to all parties. Of course, this implies that sometimes, details of prefs are not communicated clearly. How can this be? I've seen many tens of term sheets, and never once have I seen one that uses invisible ink. Neither have I ever seen a term sheet that has a clause invalidating it if you show it to your lawyer. In short, there is never a case where an entrepreneur isn't reasonably informed about prefs. Let me construct an example. Say that you're a first-time entrepreneur, and that you don't have anyone on your exec team, nor on your board of directors, nor among your existing investors, who's ever seen a term sheet before. (I was in that spot starting my first company back in 2000, by the way.) And, let's say, you get hold of a term sheet that casually throws out there something like "holders of Series A shall be entitled to an amount per-share equal to two times the per-share price..." and you don't know what it means. Well, one thing I can absolutely promise you is that no VC is trying to sneak one by you for a shot at 2x his money. A VC investment just takes way too much heartache and worry and effort -- not to mention opportunity-cost of not investing in the billion-dollar blockbuster every VC's looking for -- for a VC to fuck around with taking a chance at cheating you out of a couple million (remember, he has to give all but 20% of that profit to his investors, and split that 20% through some formula of his partnership, so even if he cheats you out of $5 M he's not going to deposit more than a few hundred $k in the bank, and that's at risk of losing his several hundred $k per year sinecure for a GP of a decent-sized fund). Another thing I can promise you is that no VC ever wants you to sign anything without reading it and having your lawyer read it twice. Think about this one for just a second: I'm about to wire you enough money to buy twenty or thirty Porsches, based on the notion that you're a brilliant businessman who's going to make us both rich. Do I want to give thirty Porsches worth of cold, hard cash to the kind of guy who signs deals without reading the contract??? Seriously: I want you to be the slickest of salesmen, the toughest of negotiators, and the most diligent of dealmakers (not to mention a prodigious engineer, a revered leader, and a master marketer). VCs do not want to give money to sloppy suckers who can't be bothered to read and understand a term sheet -- including seeking savvy legal counsel when appropriate! Now, having said all this, there are at least two cases where Leo's thinking really does apply to the question of liq prefs. (It shows of Leo that his thinking on the matter of prefs is mostly abstract, that he does not mention either of these two cases.) The first case is where you are dealing with a fake VC. A real VC is someone who spends full time managing a fund of committed capital from one or more arm's length investors, which capital amounts to at least, say, $10 M per general partner and is entirely meant to be invested in growth companies for the purpose of financial returns primarily via capital appreciation. A fake VC is anyone else who calls himself a VC without pointing out the major differences with the above. And a fake VC has God-knows-what sort of motivation and may well want to swindle you out of a preference multiple. Your uncle who owns a chain of bagel shops is not a VC. A hedge fund is not a VC. A dude who claims to represent a group of "anonymous Asian industrial families" is not a VC. Anyone who is keeping his day job is not a VC. Real estate guys are not VCs. Note that this doesn't mean they are bad people (unless they pretend to be VCs, in which case they are fake VCs). It just means that the ground rules that you can understand all VCs to play by don't apply. If you're not dealing with a real VC, read everything three times and have your lawyer read it six. The second case is in follow-on rounds where the company is in a distressed situation. Everything Leo talks about (and everything I assume in the first part of this post) is about the moment before you take your first VC investment: do I take this capital, with its strings attached, for a shot at building my dream? The alternative there is to simply walk away, and go back to working at Microsoft. But once you're hot and heavy with a company, once you've raised money, promised the moon and the stars to your friends and family, bamboozled the VCs into funding you, alienated all your social contacts and exacerbated your RSI, hired fantastic people and worked them to exhaustion and made them love you enough to drink the Kool-aid, extended commitments based on your word and your honor to customers and suppliers -- only to find that revenues aren't ramping up fast enough and you need cash -- OK, now you are officially up against a wall. And precisely now is when you will be addled from overwork, and adrenalin-high, and blinded with the urgency of your need -- and when the sharks will smell blood. That is when you will get the predatory term sheet. If Leo wants to do entrepreneurs (and VCs) a favor, he should take a hard look at what happens then: when you've got a company that still holds promise, but is in a distressed situation and needs capital for its very survival. Exploring those moral complexities is a lot more interesting than the sort of clean-room, game-theoretical chatter about whether one accepts term X on a first round of capital. $Id: vc_liquidation_preference_response_to_dirac.txt 966 2007-08-08 22:49:34Z rlucas $ Mon, 06 Aug 2007
Rails form_tag Changes in Rails 1.2
I recently updated my dev machine (Mac OS X) to the latest Rails gems, and was getting deprecation warnings for using form_tag in its old, non-block, pre-Rails 1.2 way. Then, in moving between my development and acceptance-testing boxes (you do have a mirror of your production environment running as an acceptance testing server before you push things from your laptop to production, right?) I started getting blank HTML pages out of the testing box. Whoops. Well, one thing is that the two different versions of form_tag act differently with respect to output -- so with the old one, you needed to put: <%= form_tag ... %> While the new one takes: <% form_tag ... do %> ... <% end %> (Note lack of = sign in the new, block version.) But that wasn't it. My problem was that, even with the equal signs fixed, I was getting no love from my testing box. Things that should have been enclosed in the form tag block were just not happening. My hunch was that the old version of Rails was barfing (this was sort of true: the new block form of form_tag is not backwards compatible). I updated Rails with a one-two punch of apt-get update; apt-get upgrade mixed with a gem install rails. No luck. Aha! Have to kill and restart the server process: still, I got no form tag love. I checked the Rails version with rails -v and got 1.2.3, the latest version. gem list showed that 1.2.3 was coexisting with some older versions. Aha! And a real aha this time -- for this was, it turns out, the problem. Thanks to the folks who author the acts_as_authenticated wiki. It was there that I found a reminder that the RAILS_GEM_VERSION variable, in config/environment.rb, can be set to peg which, among several possible installed versions of Rails, the app will use. It appears that if you comment out RAILS_GEM_VERSION, you get the latest installed version -- which in my case fixed it to use 1.2.3, thereby giving me my form_tags back. $Id: rails_form_tag_changes_in_1-2.txt 964 2007-08-08 00:06:56Z rlucas $ [category: /bugfix] [permalink] Fri, 03 Aug 2007
God Help You If You Get Derailed: "Model is Deprecated"
The comprehensible but often superfluous model method in Rails is used in an ActionController to tell it about an ActiveRecord model that it ought to have loaded in order to have the AR classes available to it. It's kind of got the feeling of a require or a use in Perl. It's fairly straightforward to reason by analogy about what it does. (The only confusing thing, I think, is that it works by imputing a filename from a symbol representing the class to do its "magic" so if you define multiple AR classes in a single file, you'd want to make sure that the symbol that matches the filename containing the multiple classes is what you pass to the model method.) But in a nutshell, you stick model :my_object_class in, say, the base ApplicationController class and you're good to go to use MyObjectClass and any subclasses defined in the same file. Well, it was the way you do it. Around Rails 1.2, it started barfing up preemptive deprecation warnings: model is deprecated and will be removed from Rails 2.0. So, you follow the URL they give you for more info. Unhappily, nowadays (August 2007), the page they point you to, //rubyonrails.org/deprecation, doesn't say anything about model. WTF, guys? Googling around tells you that you should use require_dependency instead. Oh, good. Way longer to type and harder to remember, but it's OK, because require is part of the language itself and is familiar to those who understand it. Er, wait: it's require_dependency, not require: it's a Rails feature, not a Ruby core language feature. Fine, you say, I'll do it if I must. Just do a replace on those lines, and you're good, right? Oh, wait again, now my app is bombing with an error 500, and the log says undefined method `ends_with?' for :my_object_class:Symbol. I won't keep you in suspense: you can't give a symbol :my_object_class to require_dependency, you have to give it a String ("my_object_class"). All of this highlights a pretty big issue with Rails. It's really an infantile, nascent culture. To keep up with it, you really need to be in constant conversation with the community (like constant: I mean, you need to be sitting in the session at RailsConf with Colloquy open on your MacBook, chatting about stuff on an hour-by-hour basis). This isn't bad, but you better understand it. And you better be refactoring your app constantly in order to keep up with best practices and to be able to use new plugins, etc. -- which also isn't bad, but it's expensive and a hassle. And to anybody who thinks a Perl app is tough to maintain: yeah, right. Try Rails code from a year or so ago if all you know is Ruby and you haven't been heavily engaged in Rails culture during that time. "Convention over Configuration" is fine and dandy as long as you're steeped in the culture that maintains the shared conventions. $Id: god_help_you_if_you_go_off_the_rails-model_is_deprecated.txt 962 2007-08-03 18:10:18Z rlucas $ [category: /bugfix] [permalink] Mon, 16 Jul 2007
VC Career Snippets: "The Wormhole"
This is the first of a series of "snippets" about getting a job in VC. I get asked about this approximately weekly, so I am going to try and do a highlights reel of things I tell people or thoughts I come up with on the topic. In a nutshell, VC is this weird parallel universe into which there are very few wormholes. (To start a career in VC) It helps to distort the space-time continuum with an extremely concentrated mass of money that you already have. $Id: vc_career_snippets-wormhole.txt 948 2007-07-17 02:32:19Z rlucas $ Mon, 02 Jul 2007 Seattle-based Open Source startup Sourcelabs put together the Swik.net wiki a year or two ago. They seeded it with some links of moderate usefulness, and for a brief time, it was a decent, if hit-or-miss, way to find information about an open source project or tool that you were considering using. No more. Not only are most of the pages I'm finding on Swik these days simply a one-link screen-scrape to the actually interesting page (which often ranks higher in Google alone, anyhow), but Swik has committed the cardinal sin of infovoria: playing audio that automatically starts on page load. (They do this by means of an auto-starting video advertisement that spams up the top bit of the page. Not quite as egregious as a MIDI object, but every bit as annoying.) Unbelievable. I thought we'd gotten past this with the turn of the millennium. But everything old, it seems, is new again. Swik, however, now gets the same mental category as "About.com," namely, ad-filled, nearly unusable results not to click when they appear in a web search. $Id: swik_has_jumped_the_shark.txt 928 2007-07-02 17:46:28Z rlucas $ [category: /tech_and_market_reflections] [permalink] Wed, 27 Jun 2007
Spry VPS Mixed Experience Report
I've been using an "el cheapo," $15 / month, 64M RAM Debian GNU/Linux VPS from Spry for a couple weeks now. Some things to note:
Too early for a verdict. But don't count on being able to run the same stuff on a 64M Spry VPS as you would on a 64M box with a half-gig of swap (grinding its way through but eventually getting the job done). $Id: spry_vps_mixed_experiences.txt 920 2007-06-27 19:10:21Z rlucas $ [category: /tech_and_market_reflections] [permalink] Tue, 26 Jun 2007 Many of these problems arise because RDBMSs are designed typically with the conceit of being the sources of truth within the organization (e.g. invoice #1234 exists because the database says so), but are often used to reflect external truths about the world, which are input messily and which themselves are often shifting or subject to change in ways not contemplated by the schema. I. The entity deduplication problem.Alice is entering information about companies, and creates a record #1001 for "Acme Widgets." She then adds a bunch of information, including relating other tables to Company #1001. For example, she may put in a press clipping about Acme Widgets, which gets linked by a link table to Company.id==1001. Then, Bob comes along entering information about companies, and creates a record #1234 for "Acme Widget Corporation." He adds stuff, and includes a different press clipping, which gets linked to Company.id==1234. Later, Charlie arrives, and notices that there are two records starting with "Acme." He investigates a bit, and discovers that "Acme Widget Corporation" is the full legal name of the company that is familiarly called "Acme Widgets." How can Charlie cause the database only to reflect a single Acme which is associated correctly with both press clippings? II. The undo problem.I do some stuff. Then I change some stuff. Then later, I want to see how it was before I changed it. Tough luck. III. BitemporalityLet's include financials on our companies! Acme revenues are $12 M. (wait a year.) Now Acme revenues are $15 M. But wait: we now need a couple of slots for revenues. Oh, ok, a revenue report is associated with a year. Acme 2006 revenues were $12 M, 2007 revenues were $15 M. Wait. I was wrong. Acme 2006 revenues were $9 M in reality. OK, update that. Now the boss calls up and wants to know who it was that we told the wrong 2006 number to. But we can't, since we don't know what we thought we knew when we thought we knew it. (In fairness, bitemporality is somewhat easier than the other ones; you just double-time-stamp everything. But it's still a pain in the ass.) IV. The incomplete multi-table entity problemThis one is not really an RDBMS problem so much as a Web applicaiton architecture problem. Doug wants to create a record in our database -- let's say, a "publication." The publication must have an "editor" (n:1) and at least one "author" (n:m, m >= 1). Doug gets to inserting the publication, but is stopped because it has a null editor_id, violating the editor constraint. D'oh! OK, we can work around this: good databases permit deferring of constraints until the end of a transaction. But in order to make that work with your application, you now must tightly couple the transactionality between the RDBMS and the server part of the Web application. Let's try again with Doug. He inserts the publication, no sweat, and now can insert an editor. Then, he adds some other stuff, like some authors. (Maybe Doug is using an AJAX-y Web front-end that lets him add new authors on the fly without going to a new "screen," or maybe he has to navigate between modal "screens" to do this.) Because he's added multiple different entities (a publication, an editor, some authors), he gets to feeling that what he's done is already written to the database. He leaves without hitting save. Do'oh! Two things have now happened: first, the entire graph of all the entities he's added is in limbo, and second, the server part of the Web app is holding open a (possibly scarce) connection to the RDBMS (which may or may not, depending on how fancy the example gets, be holding locks with a SELECT FOR UPDATE...). The first sub-problem -- the limbo -- seems not that bad, because Doug is used to losing all his data when he forgets to hit "save" on a desktop application, so he's fairly well trained and will avoid this. But if the program is "DRY" (Don't Repeat Yourself), and especially if it had modal "screens," Doug probably hit "save" or "update" or "submit" several times on interfaces that look like the normal (non-multi-table-entity graph) ones in order to add his multiple required entities (editors and authors). Therefore, Doug has a not unreasonable expectation that he's done his part for saving, based on the fact that when he edits or creates an author entity in isolation, he uses that same workflow and it saves OK. The second sub-problem -- the RDBMS connection -- is sort of more pernicious, because now Doug isn't just losing (or jeopardizing) data he though he'd saved, but because he's potentially contributing to a denial or degradation of service for all users. This is sort of an artifact of the way that DB connection pooling evolved from the mid-90s to today. Traditionally, DB connections have been scarce and costly to set up (network IO in addition to whatever socket / semaphore / locks / whatever had to be written to disk). Therefore, the widespread practice evolved in Web application design to use connection pooling -- where some subsystem in the server layer makes a bunch of connections to the database, and then does fast handoffs of DB connections to application requests, freeing them up when each request is done. That way, you can run, say, 300 near-simultaneous requests with, say, 30 database connections. Of course, if you're pooling database connections, you pretty much have to run your entire transaction, succeed or fail, within the space of one application request (hopefully a sub-500ms affair), since transactions bind to database connections, but connections don't bind to end-clients (stateless HTTP again). You can try and bind the DB connection to a particular client's cookie- or token-identified session (like Seaside does, I think), but then you lose out on the ostensible benefits of pooling -- now you need 300 RDBMS connections for your 300 clients, and your DB machine is choked. What's more, if Doug leaves his transaction open, and you don't fairly quickly time it out and kill it, you could end up needing more than 300 DB connections for your 300 clients, because you also have 300 old "Dougs" who've left stale transactions open -- and now your DB machine is crashed. I will update this post periodically with other relational database problems, and, I hope, solutions. $Id: relational_database_problems.txt 933 2007-07-06 17:17:05Z rlucas $ [category: /tech_and_market_reflections] [permalink] Fri, 22 Jun 2007
Apple Occasionally Kicks Ass: A Tech Support Experience
Last night, I was typing happily along on my MacBook Pro, unplugged and on battery power with about 40% indicated remaining, when bam, the power went right out like a light. Curse words. Flipped the thing over, and got no LED action from the battery charge indicators. Plugged it in and it would boot, but pull the plug and it goes down hard again. I had just bought the thing in December 2006, refurbished direct from Apple and with a 3 year Applecare extended warranty. Well, I hopped on the bike and made it to the Apple store in the peculiar ring of hell known as "University Village" (an upscale retail cesspool here in Seattle. Aside #1: Never go there. Aside #2: When you must, ride a motorcycle or bicycle, because parking is impossible, and the sheer Schadenfreude of watching the SUVs joust and jockey while you glide to within a few meters of your destination almost makes the place bearable). The Apple storeites had me belly up to the Genius Bar (their open-air repair facility). I handed the MacBook over with a brief description of the problem. As the guy was keying in something (serial number?) he started to regale me with an explanation of the normal sleep procedure and how the battery is supposed to work. "Oh shit," I thought, "here comes runaround city." The guy leaves, I get ready to get comfortable and either wait it out or raise sufficient hell to get what I need. To my surprise and delight, when the "Genius" returned, he had a box in his hand just slightly bigger than the batter in question. Snip, snip, out comes the battery, and into my laptop it goes. Hands it over without a word and gets to printing me a receipt. Holy shit -- he just silently and competently fixed my problem, without me paying a dime or sitting through any bullshit (other than the complimentary, brief lecture on hibernate vs. power down while he looked up the inventory for the replacement part)! Too many other tech repair facilities have long algorithms they have to go through, debugging procedures, etc. -- all of which ostensibly save money on parts but waste uncounted hours of techs' and customers' time. Apple, despite really dropping the ball when my wife's laptop started crashing intermittently eleven-and-a-half months into owning it, really came through on this one. Pros: This is exactly how customers should be treated. Fix it. Sign for it. Send 'em on their way. Go Apple! Cons: This probably means that the Genius bar sees quite a few cases of MacBook Pro battery-sudden-death. $Id: apple_occasionally_kicks_ass.txt 910 2007-06-22 16:55:05Z rlucas $ [category: /tech_and_market_reflections] [permalink] Thu, 21 Jun 2007
Truth and Fiction in Motorcycle Gear: Cortech DSX Jeans
I've been looking for good, mostly-civilian-looking riding jeans with armor and abrasion resistance. Cortech DSX Jeans use leather instead of the kevlar / aramid that some (e.g. Draggin' Jeans) use in the knees and seat. They do have some knee armor. Plus, the price was right (about $70 shipped) vs. the kevlar ones, so I ordered a pair. Levi 501s in 38" waist, 32" length fit me pretty well. Snug, perhaps, but not tight (neither gangsta nor European). So, I was hoping to get a similar fit out of the Cortech DSX. At risk of giving you more info than you need, I have kind of thick legs, a residue from too much rowing in college. No such luck. Cortech DSX jeans are cut for fatasses. The 38" waist hangs off me like a 40". I have to cinch it up so much with my belt that there's a fold. I really ought to have it taken in 1-2 inches by a tailor. And my thickish legs flop around in the bagginess of the jeans. The cut of the jeans is sort of a low-rider type thing. These are definitely cut to be worn lowish on the hips (lowish for men's jeans, that is; not hip-huggers, but probably 4" lower on the body than Western jeans). Accordingly, the 32" seems to be measured from the floor to a lower height than with e.g. Levis or more Western type jeans. When I sit on my bike, the jeans pull up almost to the top of my Cortech Tourmaster riding boots. Long story short: if you wear a 38-32 in Levi 501s, you probably should order a 36-34 to get jeans that 1. fit snugly (and therefore keep the armor and leather in place), and 2. don't ride up when you're on the bike. Other than that, I can't complain. They are some nice jeans, they just happen to be cut without reference to the actual measurements on the tag... $Id: truth_and_fiction_in_motorcycle_gear-cortech_dsx_jeans.txt 906 2007-06-22 01:27:20Z rlucas $ Tue, 12 Jun 2007
Truth and Fiction in Motorcycle Gear: Olympia "Waterproof" Gloves
Motorcycle gear is tough to buy. There are lots of places that sell some stuff, but precious few that sell a really good selection. Also, there are tons of vendors available online, but since you can't touch or try the stuff before you get it, you're SOL. My goal is to write up all the moto gear I buy so that folks can make good decisions about it. To kick it off, I'm going to pick on Olympia's "Waterproof" gloves. My first pair of bike gloves were the Olympia Cold Throttle gloves. These worked well for me in coldish weather (say, 40's; it would get chilly in there but livable). However, after a single day on the MSF course range during a rainy March day, the gloves were completely soaked through. (In fact, they got totally soaked in the first 4 hours or so of rain.) I don't mean that they leaked -- which they might have -- but that the leather itself was completely soaked. You could take the glove off and literally wring out the leather and have ounces of water come out. I couldn't get the glove dry overnight, even putting it on top of a fan on top of a heater all night. Still, when not wet they worked well and fit nicely. Plus, the longish nylon gauntlet played nice with my textile jacket and prevented water from coming up the sleeve, at least. Then, a couple weeks into owning the gloves, the pull-cord-to-tighten-stopper-thingy (the thing you squeeze to let the cord loosen up) just snapped right off of one glove during a routine closure of the cord. University Honda was good enough to take them back on a warranty replacement and give me a new set. "Maybe," I thought, "this pair will actually be waterproof!" Well, no such luck. A 20 minute ride in a steady rain last Saturday soaked the leather straight through. (Now, it should be said that all gloves will accumulate sweat inside of them, whether or not they keep out rain. This is, of course, what Gore-Tex ostensibly fixes. Note that it won't fix it fully, because the sweat vapor really has nowhere to go when the outside of the glove is covered in water...) So, although I have read good things about Olympia on the web, and although these gloves offered beefy knuckle protection and good insulation when dry, I can't recommend the Olympia Cold Throttle "waterproof" gloves for any wet applications. $Id: truth_and_fiction_in_motorcycle_gear-olympia-waterproof-gloves.txt 894 2007-06-13 17:26:18Z rlucas $ Wed, 30 May 2007
Highway 202 North of Snoqualmie Falls Sucks Right Now
A quick note for any of you thinking of heading out to Snoqualmie Falls en moto right about now (late May 2007). The road getting there from I-90 was just fine, and indeed, at the falls there were plenty of bikers (no place to park, even!). However, if you continue north on Highway 202 (SE Fall City-Snoqualmie Rd) after the falls, you'll hit about a mile of twisties with heavily grooved pavement. It sucks. Be real aware of this if you're planning to visit (or pass by) Snoqualmie Falls on your bike this summer -- hills plus curves plus thick grooves make for an unpleasant if brief part of the trip. $Id: hw_202_north_of_snoqualmie_falls_sucks_right_now.txt 879 2007-05-30 15:55:43Z rlucas $ Wed, 16 May 2007
Just How F'ed Is The U.S. Dollar? I'll Tell You.
Here's how F'ed the U.S. Dollar is right now. If you go for a bit of shopping in Montreal over the weekend these days, you probably pay with your credit card to try and get the best exchange rate. When you next get online and look at your credit card statement, you will be shocked to find: the USD-CAD exchange rate is so poor right now that, after taxes, you pay more U.S. dollars for your purchase than the price tag in Canadian dollars originally said! Cheers to our northerly neighbors, I guess. (Although it does kind of put the lie to the whining I heard from some Ontario snorkelers when in Florida, that the boat skipper ought to give them a break on account of exchange rates.) $Id: how_effed_is_the_us_dollar.txt 880 2007-05-30 16:03:57Z rlucas $ [category: /finance] [permalink] Thu, 10 May 2007
Printing From Mac OS X Without Going Bankrupt
One thing about buying a new(ish) MacBook Pro loaded with Tiger: they really aren't cutting a lot of corners. This includes in the area of resource usage (see e.g. memory usage, as you buy another gig of RAM). This, of course, is done in the name of an "Insanely Great" user experience, and mostly, it works. One difference from Windows is that the Mac, when printing, defaults to the best mode possible on our big office multifunction color laser printer; in this case, it's fully glossy color. Those of you who've ever had to buy toner for such a printer are now wincing: it is damn expensive. In Windows, it seemed, I had to opt in to print in color. I'd like to run the same sort of system on my Mac. Well, as it happens, this is one sad case where the Mac requires you to know more about how the OS works than does Windows. Specifically, we want to use a feature of "Quartz" (the graphical engine) to convert colors to greyscale before sending them to the printer. Do it like this:
$Id: print_on_your_mac_without_going_bankrupt.txt 865 2007-05-10 16:49:40Z rlucas $ [category: /bugfix] [permalink] If you want to move longer distances than your legs (walking or biking) carry you, such as between major cities or, within our metropolises, from the mire of suburbia to the oases of interestingness, and the generally crappy mass transit options found in the U.S. aren't compelling for your purposes, it seems that you really have no choice but to give in to car culture and become an automobile driver. This is a shame, because obligate car culture frankly sucks. It's wasteful not only of fuel but of resources in the cars themselves. Worse, it constricts the mind's range by giving a low-activation-energy default pathway for transportation needs, and promotes a positive-feedback loop of car reliance (I have to drive around and find parking so that I can, er, drive some more). And that's just the effect on the driver; obligate car culture does horrific things to neighborhoods, commercial districts, etc. (I use the term "obligate car culture" to define a style of living and interacting that requires a car. Rich people, poor people, hippies, students, bobos, and some yuppies can escape this. But the vast numbers of Americans living in suburbs and exurbs -- who can't walk, bike, or reasonably quickly (circa q 15 minutes) get on mass transit to get to places to work, eat, shop, play, and socialize -- are obligated to have access to a car or be a pariah.) In fairness, the pluses of car driving -- when everything goes right -- are substantial. For a small price, you can go any distance from a few blocks to all the way across the country. Modern vehicles, even the cheapest, are amazingly reliable (if wanting in many other aspects of engineering) and capable of exceeding legal performance limits. The interstate system is a marvel and will take you within a mile of every urban center in the land. But a car is at least a metric ton of steel, glass, and assorted crap that you're dragging with you, despite the fact that a knowledge worker typically only needs himself, some papers, and perhaps a laptop wherever he goes for work. But there's another means to getting your transportation needs fulfilled. A personal, more human, and cheaper way to travel at high speeds. That way, is, of course, via motorcycle (or scooter, as the case may be). Let's take a look at some of the benefits of travel by motorcycle:
The downsides are worth considering:
The negatives do have some mitigating factors that should be mentioned, though. In the case of accident and injury factors, you can self-select out of the highest-risk categories with three easy steps. First, take a course, such as the Motorcycle Safety Foundation's Basic RiderCourse, which qualifies you for a motorcycle endorsement to your license. This takes you out of the dangerous "self-taught" and "friend/family taught" categories, and takes you out of the "unlicensed" category (NEED CITE). Then, buy appropriate head-to-toe gear -- "no skin below the chin" -- including a full-face helmet. The helmet alone reduces your risks of the most grievous injuries and death substantially -- but make sure it's full-face, since post-crash analyses of helmet damage areas show that the chin bar takes damage in about a third of head-banging incidents. Really quite decent gear can be assembled for the low side of $500 -- consider it a one-time spend of the first year's car-vs-motorcycle insurance delta. Third, never drink and bike -- even if you're the type who will drive after a beer or three, change that habit for the motorcycle. Studies and anecdotes suggest dangerous impairment well below .08 % BAC for motorcycling (NEED CITE). And there -- with three simple maneuvers -- you've sliced out huge chunks of the risk of major injury or death. Perhaps not quite as safe, still, as being in that SUV, but a minimum of $25,000 cheaper and a thousand times cooler.
(Helmet damage distribution. Used without permission from flamesonmytank.co.za, who in turn used it without permission from David Hough's Proficient Motorcycling.) Regarding weather, you'd be amazed at how good the waterproof textile gear can be. I spent a full 8-hour day in the pouring Seattle March rains, doing low-speed exercises outdoors in an instructional course, and my Firstgear jacket kept me completely dry and entirely warm from the waist up, including protecting my cell phone from the elements. (My bottom half, in makeshift "water resistant" gear, was completely soaked.) Gore-Tex is off patent these days, and so everyone and their brother uses it or a knockoff to make waterproof, breathable materials. The technology is to the point where you can practically dress up in black tie, then slide on your waterproof gear, head out in the rain on your bike, and upon arrival, shed the wet stuff and emerge no more rumpled than you might get sitting on a crowded train or bus. So, when it comes down to logistics, how does a carless urban yuppie type (like your humble correspondent) actually effect becoming a biker? 1. Find a Basic RiderCourse, sign up, and take it. Mine was 12 folks; about 2/3 owned bikes already, and 1/3 were complete novices. I'd been on a bike once (tearing up empty lots on a buddy's dirtbike down in Oregon as a teenager, before flipping the thing upside down in a misguided wheelie attempt), but there were at least two folks who'd never ridden in their lives. Around Seattle, market for the unsubsidized courses is $240 for an evening of classroom work and two days of riding (state subsidies bring the cost to $100 for some dates, but those fill up fast). 2. If you're still positive after the course, get your license endorsement. Generally you have some period of time from passing the course to presenting it at the DMV. Washington wants, I believe, $25 for the chore of endorsing your license. 3. Sketch out a feature range and price range for your bike. I recommend spending time on dealership websites to get a feel for new prices and the various available models; then, do likewise on Craigslist and eBay to get the used prices and the (different) models available. Bikes last forever if properly maintained, and it's not unusual to find Japanese bikes from the 1970s offered for sale today. 1980s bikes are even more common. (However, surviving bikes from the '60s and earlier become expensive collector's pieces.) But these are distinctly different types than one sees today. Since the late 1990s, bike manufacturers have concentrated on two kinds of street bikes: cruisers (kind of "chopper" or "Harley" lookin' types, low seat, chrome, forward foot position) and sport bikes ("crotch rockets", with bright colors and plastic, with a forward lean and a rearward foot position). This has pretty much meant the death of the "standard" motorcycle, though Honda still makes the Nighthawk in this category. Another victim of this change is the mid-displacement bike. It used to be that one could buy motors in 125, 250, 450, 600, 750, and 1000 cc sizes (roughly). Now, the 250 cc motors are still around on Yamaha Virago and Honda Rebels, but there's really nothing until you get to 650-750 cc engines. This is widely viewed as a shame because a 450 cc standard bike, such as might have been common in the 1980s, is a great starter bike but is unavailable new today. (However, see below for a caveat on buying an older bike.) 4. Find a place to get your bike worked on and to park it. These two logistical hurdles are not insubstantial. A lot of the cheaper bikes you'll find for sale are sort of DIY projects on wheels; unless you have, or want to acquire, tools, skills, time, and a work area, you'll need to trade your treasure to someone with these things. Complicating matters, dealerships and service facilities sometimes limit the model years they will work on. This will, therefore, interplay with #3 above. (This was a factor in my decision to buy used from a dealership.) Parking, depending on your area, may require permits for on-street, or may require a parking pass. However, be sure to ask around for "boots-on-the-ground" info about motorcycle parking in your neighborhood. There are certain facilities and areas where one can park a bike for free, but these are unlikely to be publicized on the Internet for fear of overuse or loss of the privilege, so talking with local bikers, garage attendants, etc. can be rewarding. 5. Find a way to get the bike home from purchasing it. (I agree with the author of the article linked above that riding the bike home is a last resort; I did so, but it was under half a mile, early on a weekend morning.) If everything is cool, you may be able to ride home from the purchase, but you may need a trailer. The carless yuppie will note that U-Haul offers motorcycle trailers at a reasonable rate, which trailers may be attached to one's rented truck. Alternatively, if you're the kind of carless urban yuppie whose friends drive cargo vans or pickups, strike yourself a deal. 6. Get the gear. Full gear, no excuses. Budget $60-200 for a helmet, $80-300 for a jacket, $50-200 for pants or chaps (chaps not recommended; the not-too-squeamish can look at this for evidence), $20-60 for gloves, and $60-200 for boots. The boots are kind of negotiable; good work or hiking boots will work for starters. Otherwise, get motorcycle stuff: no football helmet, no fashion leather, no garden gloves. Ebay can be a source for very cheap entry-level stuff. 7. Inspect, negotiate, select. Look at several bikes. You might not get test rides; dealer insurance issues and private-owner reluctance are unfortunate but standard problems. Get a checklist such as the Used Motorcycle Evaluation Guide to help you walk through the inspection process. Other online buying guides can help you with this process. You should have ammo for negotiation from your online research into the models you want: make sure that among your data points you have recent comparable asking prices from e.g. Cycle Trader or Craigslist, actual closing prices from eBay, and Kelly Blue Book values. Try not to get walked on; read a book or two on negotiation. FYI, the dealer I dealt with opened with a highball for almost 30% higher than our final sales price (though our final deal included things like cash payment, additional gear purchases, etc.; these are gives you, too, can offer in exchange for a lower price). Don't take possession right then! Finalize your deal and schedule pickup for the next possible day (Fridays are therefore good for this). Before you leave, get the VIN (Vehicle ID Number). 8. The night before. Check the VIN online; depending on the price of the bike you're acting on, it may not be worth paying for a full Carfax-style report, but you should definitely Google around; see if anyone has posted the VIN as stolen; make sure that the make, model, and year as represented to you match up with the manufacturer's coding scheme for the VIN. 9. Get insured. You can sign up for insurance online. I used Progressive to get a quote that ran $330 annually. At that price (and given my good experience with Progressive in the past), it wasn't worth shopping around for a 10% discount. YMMV. A modern insurance company should let you not only sign up, but add a specific vehicle (by VIN) and print out insurance ID cards, all online and within minutes. (Again, YMMV: Progressive's lack of sucking may not be representative of all insurers.) 10. Take delivery. Use good practices if buying from a private party, such as a written bill of sale. If you must ride it home, ride real safe! Once home, make sure that you've got all the state paperwork underway and, if you're going to ride before getting back any tokens from the government that you need fully to be legal, try carrying copies of what you sent in, to try and get sympathy from any possible cop stops until you become "official." 11. Practice slow and easy for starters. Even if you live in a dense urban environment on a steep hill (like your correspondent), you can find a block to circle around so as to get a feel for the bike. Please, and this is important, please just ride like a total pussy for the first couple days and several hours. It's important to remember that you're already 10x more badass than anyone else who's not a biker at this point, so just slow it down, and do exactly like you learned in class. Don't worry about delaying or slowing down motorists while riding around your neighborhood, or about seeming odd for running the same route ten times -- naysayers can kiss your ass. There are no bonus points for scraping off someone's side-view mirror an hour into owning your new ride (except for the extra caution karma that you will then enjoy for quite some time...). 12. Use a checklist like the one at (NEED CITE) to step up your riding over the next several days and weeks. Take graduated steps out of your comfort zone. Don't stick to parking lots; you've got to push yourself to expand your skills and confidence. As you grow, continue to read, perhaps starting with David Hough's "Proficient Motorcycling." Here are some other tips: 1. If you're busy, start this process in the late winter (early spring if you've got time to move through it rapidly). As spring moves in and the rains stop, sales pick up, and with the extra demand so go prices. This is also true for things like occupancy at the classes, lines at the DMV, etc. If you're ahead of the curve, you'll be riding with less time and capital outlay. Plus, taking the MSF class in absolutely dismal weather (large swaths of our riding range were covered in multiple inches of water, and it rained for about 12 of 16 hours) means the first time the weather turns sour during a ride, you're not experiencing something new. 2. If you've heard that "everyone lays it down in the first year of riding," think again. My riding instructor reports that he has never, in 20 years of riding, laid it down. Is he phenomenally skilled or just lucky? Probably a mix of both. But if you follow this guide (and / or other good info sources) there's no reason why you can't be the same way. On the other hand, wearing All The Gear, All The Time (ATGATT -- not, as it might seem out of context, some sort of six-base-pair polymorphism conferring hereditary safety-mindedness but an acronym for volitional safe behavior) is your way of hedging that bet. 3. Take the time to research the concepts of "countersteering" (not "counterweighting") and "high side" vs. "low side." The topics are too involved for me to delve into here, but suffice it to say that countersteering (push right, lean right, go right) is the only way to turn your bike above about 10 MPH, and a low side is a relatively "nice" crash where the rider goes down low (usually below / behind the bike) while a high side is the perilous case when the rider goes over the bike, sometimes to be followed by the bike itself! Neither topic is covered very well in the Basic RiderCourse, and in one case, my instructor gave bad info about countersteering due to a terminological error. An estimate of the time and money spent on this:
Yes, that comment about smashing off a guy's rear-view mirror is from real life. Sucked to be me. You could do this for about half the price I paid, if you're willing to cut some corners and do a lot of the maintenance-type stuff on an older bike yourself (and not crash). You could also easily spend twice or even three times this (there were some people in my class who were bragging about financing $16,000 worth of purchases from the Harley dealership; good for them, I guess). $Id: how_to_be_a_biker.txt 901 2007-06-15 05:39:53Z rlucas $ Wed, 09 May 2007
Making Subversion Set Reasonable Default Properties Like Keyword Substitution
(Programmers: skip down to the Meat section below.) If you are so bored as to actually have read all the articles on this blog, you may have noticed that the "Id: lucas blah blah blah" string that shows up at the bottom of the articles. This is an interpolated keyword, put in by the revision control system, that shows in the text of the document when it was last committed to revision control. Subversion (svn) is a revision control system -- probably the leading such system for new deployments (I am not counting Microsoft-land, where old, proprietary systems still abound). It's most familiar as the replacement for the venerable CVS, which used to do replacement more or less automatically. But a stock Subversion install won't do keyword replacement unless you do a "property setting," or propset, on a file-by-file basis (this is to prevent clobbering a file that happens to have the magical string in it). Therefore, you have to remember to do something like this to your new files: svn propset svn:keywords Id myfile.txt This tells svn to set the "svn:keywords" property to "Id," meaning it will replace instances of $Word: $ with the ID string (when "Word" is "Id"). However, this is a pain, and although you could conceivably script this action as a hook upon new additions to svn, there's an easier way. Meat Find your local ~/.subversion/config file and edit it. Set the following: [miscellany] enable-auto-props=yes [auto-props] *.txt=svn:keywords=Id (The default config file has a bunch of examples commented out for you to base your settings on, but the above is the minimal set to get textfiles set with keyword substitution for the "Id" keyword.) $Id: svn_set_default_properties_like_keywords.txt 858 2007-05-09 17:21:17Z rlucas $ [category: /bugfix] [permalink]
Ruby's ActiveRecord Makes Dropping to Raw SQL a Royal Pain (Probably on Purpose)
The opinionated programmers behind Rails have generally done a good job. (There are couple of FUBARs in their bag of tricks, such as the boneheaded choice to use pluralized table names (in some places) and use automagical pluralization code to try and mediate between the singular and plural.) There's another item I'd like to bring up, however, and that's the fact that ActiveRecord intentionally cripples your ability to do raw SQL queries. This is, I'm sure, done to discourage raw SQL hacking in favor of using the ActiveRecord objects (which, for small numbers of objects, is admittedly a superior way to do many things, because of concerns for clarity, maintainability, etc.). However, sometimes you need SQL, dammit. Especially when you're doing a correlation between, say, different tags that describe business plans, and the people that link those business plans together, plus the number of times that such tags appear, there's just no sense in pulling thousands of records into memory, instantiating Ruby objects, and improperly reimplementing basic CS sorting algorithms to link them up. You've got all that sitting right there in your RDBMS. ActiveRecord lets you do something like this:
Which will run the complicated SQL and replace the bind vars (question marks) in the raw SQL with var1, var2, var3, etc., and give you a bunch of BusinessPlan objects that it's instantiated off those IDs. Easy enough. But what if you need not merely to get the objects, but to get some other important info (say, COUNT(something)) out? You're shit out of luck with ActiveRecord. The .connection.select_all method returns you an array of record hashes, but it requires fully-baked SQL (no bind vars).
WTF? If you read the code for the find_by_sql method, you'll see:
Given this, you might think: "aha, I'll just use a similar method and pass to sanitize_sql an array with my SQL and bind vars, then pass that on to select_all. No can do. sanitize_sql is a protected method. So, here's my encapsulation-breaking, OO-unfriendly, scofflaw workaround to let you have access to what you should already get: a decent bit of code for binding SQL parameters: (In helpers/application_helper.rb) arb = ActiveRecord::Base def arb.sanitize_fucking_sql(*args) sanitize_sql(*args) end Now, you can happily go about your business and, when necessary, call ActiveRecord.sanitize_fucking_sql(...) to get 'er done. No special-purpose DB connections, no wrangling thousands of objects in memory. Caveats:
$Id: ruby_active_record_makes_raw_sql_a_royal_pain.txt 863 2007-05-09 18:07:04Z rlucas $ [category: /bugfix] [permalink] Tue, 08 May 2007 ... and for Jeremy Smith. Thanks to Jeremy's hack on top of Ingy's quickie wiki, we can now get proper behavior inside of table cells. In a nutshell, Kwiki didn't handle things like italics inside of a table. This should fix it. Previous posts that used the stock Kwiki should be fixed now. Now, to remedy blockquotes ... $Id: hurrah_for_kwiki.txt 857 2007-05-09 17:10:14Z rlucas $ [category: /bugfix] [permalink]
The Housing Bubble and General Financial Depravity
Yesterday the Seattle Times brought us this gem:
In a nutshell, the country is going to hell in a handbasket. When people are so poisoned with the mindset of entitlement that they literally can't comprehend why having no cash and a negative $20k net worth doesn't qualify one to incur a quarter million in debt, well, it's hard to believe that these are the attitudes and values that built the greatest economy in the world. $Id: housing_bubble_and_general_financial_depravity.txt 862 2007-05-09 18:06:16Z rlucas $ [category: /finance] [permalink] Thu, 29 Mar 2007
Installing RMagick on OS X with Fink
Hold on: I'm not sure that the below works right. Don't use it yet. There are lots of instructions out there for installing RMagick, which is a graphics manipulation library used by many Ruby-istas for things like thumbnailing, resizing, etc. I wanted to use it for an internal database I'm building in Rails. Some of the sites offering instructions:
But nobody seemed to have a Fink-friendly way to do this. If you naively try to install with gem install rmagick, you'll get something like: configure: error: Can't install RMagick. Can't find libMagick or one of the dependent libraries. Check the config.log file for more detailed information. My solution: 1. Install the needed dependencies from binaries using Fink. 2. Use gem install to install RMagick (the Ruby bit) itself. The dependencies include (as best I can tell): freetype freetype-shlibs imagemagick imagemagick-dev imagemagick-shlibs ghostscript ghostscript-fonts gv libpng-shlibs libjpeg libjpeg-bin libjpeg-shlibs lcms lcms-bin lcms-shlibs libtiff libtiff-bin libtiff-shlibs Therefore, you should probably be able to install simply by doing: sudo apt-get install freetype freetype-shlibs imagemagick imagemagick-dev imagemagick-shlibs ghostscript ghostscript-fonts gv libpng-shlibs libjpeg libjpeg-bin libjpeg-shlibs lcms lcms-bin lcms-shlibs libtiff libtiff-bin libtiff-shlibs sudo gem install rmagick (I realize that this is probably overkill and that you don't actually need all those packages above. If you figure out the minimal subset, why don't you post a similar blog entry of your own?) Good luck! $Id: rmagick_on_osx_with_fink.txt 863 2007-05-09 18:07:04Z rlucas $ [category: /bugfix] [permalink] Wed, 21 Mar 2007
VC Essential Tensions: Momentum vs. Contrarianism
It is my intention to begin a series of entries dealing with "essential tensions" in investing in general and VC in particular. This is the first of the series. Venture capital as an industry deals with momentum investing. Paul Kedrosky has argued on his Infectious Greed blog that VC is a "bubble business," and that venture returns, when they're good, come from momentum-fueled exit events. This is an argument where the counterexamples are the exception that proves the rule: Google's IPO (unimpeachably a deal that stands on its own merits rather than a momentum exit) stands out for having decisively ended the exit drought that had plagued the industry since 2001. Indeed, GOOG going out kicked off the recent positive-momentum exit cascade that gathered steam throughout 2006. Likewise, on the "entry" side of new financings, momentum tends to rule the day (especially when exit momentum "spills over" into fundraising and new financing activity). See, for example, the cavalcade of YouTubettes that have been trotted out, freshly funded and hoping to hit warp 10 and slingshot off the perceived stellar performance of online video and user-generated content. (Indeed, it would take some backwards time-travel for most of these to capture any fraction of the value in that particular space.) It is easy self-righteously to laugh at the absurdity of funding 30 YouTubes. But if we accept whole-heartedly the ad absurdum version of Kedrosky's argument, we can't blame VCs for believing in momentum. After all: if folks today are buying online video companies, then the savvy VC better have one to sell. But investing is not a game played alone, and contrary to the bluff and bluster of some VCs, no deal is "binary." Every deal is implicitly an auction, with a bid and an ask, and the formula for investment return is ancient and venerable: buy low, sell high. Momentum helps with the latter, but crushes our ability to do the former. Apart from the occasionally perverse incentives provided by large, fixed fund sizes, pricing going in is even more leveraged in ROI than pricing coming out. Getting into a good deal at an attractive price -- and hence, the longer lever on ROI -- depends on a virtue diametrically opposed to momentum, namely, contrarianism. The contrarian looks for undervalued purchasing opportunities by ignoring or subverting the prevailing wisdom of the day. He makes it his job to call the tops or bottoms of markets, and sometimes is the one declaiming the emperor's nudity. An occupational hazard of this is that sometimes, the market has a ways to go yet, and occasionally the emperor still has flesh-colored tights on -- and early is the same as wrong when timing markets. Certainly, if there is a mythical hero of venture capitalism, it is the steel-nerved visionary contrarian who makes what looks like a long-shot bet, boldly doubling down when others are fearful, and propelling forward great companies and great technologies that nobody else dared touch (and hence, that he invested in on the cheap). Where else do we get the nerve lionizing our asset class as "venture?" So, we are faced with a contradiction between the mythology of our industry and the harsh reality. You don't get to be both the visionary contrarian and still have the online video portfolio company. Why do so many venture firms seem to choose momentum in this tradeoff? I have two theories. One is that, although entry price has more theoretical leverage over ROI than does exit value, exits are so much more visible that they dominate the consciousness of most VCs. That is, given the implicit opportunity to make a 8x ROI on, say, a $60 M exit, or to make a 2.5x on a $500 M exit, and assuming that the probabilities and amounts are adjusted to keep other comp and performance measures ceteris paribus, I bet that VC decision processes are strongly skewed to the big dollar, highly visible exit. Half-billion IPOs are much better bragging fodder at the VC confabs than mid-market M&As, even though the latter may well pay off better. This would be a great master's or Ph.D. thesis if one could substantiate and measure the value of this skew. The second theory is a general theory for understanding why contrarianism, itself, is "meta-contrarian" (that is, why contrarianism is selected against as an investing style). I call this the "rich friends theory." I use it to explain why, despite all rationality, U.S. investors tend to overweight U.S. equities in their portfolios. In a nutshell the theory is this: it sucks far worse to miss out on an investment opportunity that all your friends have scored on, than it does to miss out on an equally profitable opportunity that everyone else missed, too. Put another way, it's awesome to get richer than your friends, but it's way worse to get much poorer than them. Thinking of this "peer-relative risk aversion" helps to understand a lot of bubble / momentum dynamics. This, too, would be fascinating to measure, although I can reasonably set a lower bound here of 0.7% skew toward the crowd, which is the "rich friends tax" you pay in incremental house edge at craps by playing the pass line (the "do's," where most players play, has a house edge of 1.41%) vs. the don't pass line (the"don'ts," almost diametrically opposed to the do's, where winning earns you enmity and losing earns you jeers from your fellow punters, has a house edge of 1.40%). There's also a case to be made that emerging managers hew more closely to the herd because it could be an existential crisis to a firm for its first fund to be a "fourth quartile" performer. Much better for a new firm to post median returns and live to raise more funds, than for it to risk lagging returns on a series of contrarian bets (better, that is, for the firm, if not for its investors, who may in fact be better served by the longer-shot odds). This is, of course part of the "tyranny of IRR," about which I have another blog entry under preparation. I wish I could say that understanding, or even measuring, these effects gives you some kind of instant edge in investing. But, alas, this is a perfect example of the occasional frustrating impotence of mere understanding. (I do have some ideas for exploiting this particular case, but those obviously aren't public.) $Id: vc_momentum_vs_contrarianism_essential_tension.txt 838 2007-03-21 20:31:25Z rlucas $ Mon, 12 Mar 2007
VCs Are Not Your Channel (But They Might Be Your Friends)
Occasionally I get calls from folks who get the bright idea that, since VCs have a bunch of portfolio companies under influence, they can leverage selling their stuff by talking to me instead of pounding the pavement to the whole portfolio. If you're thinking of doing this, remember that we (VCs) are not your personal sales channel into our portfolios! Consider:
Now, all that said, there are some cases where using VCs for leverage into their portfolios does make some sense.
| ||||||||||||||||||||||||||||||