<?xml version="1.0"?>
<rss version="2.0.">
  <channel>
    <title>Advogato blog for raph</title>
    <link>http://www.advogato.org/person/raph/</link>
    <description>Advogato blog for raph</description>
    <language>en-us</language>
    <generator>mod_virgule</generator>
    <pubDate>Sat, 17 May 2008 14:48:47 GMT</pubDate>
    <item>
      <pubDate>Sun, 1 Jul 2007 23:53:02 GMT</pubDate>
      <title>1 Jul 2007</title>
      <link>http://www.advogato.org/person/raph/diary.html?start=415</link>
      <guid>http://www.advogato.org/person/raph/diary.html?start=415</guid>
      <description>I was very disappointed to read "&lt;a&#xD;
href="http://google-health-ads.blogspot.com/2007/06/does-negative-press-make-you-sicko.html"&gt;Does&#xD;
negative press make you Sicko?&lt;/a&gt;"&#xD;
at the Google Health Advertising Blog, and the &lt;a&#xD;
href="http://google-health-ads.blogspot.com/2007/07/my-opinion-and-googles.html"&gt;followup&lt;/a&gt;&#xD;
post didn't do&#xD;
much to ease my concerns. A large part of why I love working&#xD;
at Google&#xD;
is how seriously we take the philosophy of "don't be evil,"&#xD;
and it's&#xD;
not hard to see how some people might conclude from those&#xD;
posts that&#xD;
we're backsliding on that. But what I see on the inside is very&#xD;
encouraging - lots of internal discussion about what the&#xD;
right course&#xD;
of action is, and a strong commitment from people all up and&#xD;
down the&#xD;
community to act on principles rather than just the profit&#xD;
motive.&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; Don't get me wrong, Google is in the advertising&#xD;
industry.&#xD;
It makes us&#xD;
a lot of money, and we are very good at it. In fact, I think&#xD;
that the&#xD;
type of ads that we do best -- connecting people who are&#xD;
looking for&#xD;
something specific with providers who offer it -- have lots of&#xD;
potential to improve the way healthcare is delivered in this&#xD;
country.&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; But I cannot agree with Lauren's claim that&#xD;
"advertising is&#xD;
a very&#xD;
democratic and effective way to participate in a public&#xD;
dialogue." I&#xD;
think that depends a &lt;i&gt;lot&lt;/i&gt; on the kind of advertising&#xD;
we're talking&#xD;
about. At its best, it can indeed be democratic. Here's an&#xD;
example:&#xD;
it would be well within the reach of the yoga studio where&#xD;
my mom&#xD;
sometimes&#xD;
fills in as an instructor to buy some AdWords on&#xD;
"hypertension" for&#xD;
their local area. Then, when people search on that keyword,&#xD;
they'll&#xD;
see ads for the yoga studio mixed in with those for&#xD;
medications and&#xD;
high-tech hospital facilities for managing hypertension.&#xD;
Perhaps not&#xD;
&lt;i&gt;quite&lt;/i&gt; as prominently based on the size of the ad buy,&#xD;
but good&#xD;
enough.&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; This type of scenario isn't even really competition.&#xD;
Most&#xD;
doctors&#xD;
would be &lt;i&gt;thrilled&lt;/i&gt; to see their patients proactively&#xD;
making lifestyle&#xD;
changes to prevent the need for expensive medicines and&#xD;
treatments. At&#xD;
the same time, if you have a serious heart problem, my mom would&#xD;
definitely want you to get good diagnostics done, etc. Different&#xD;
story, of course, if your BP is just a touch high because&#xD;
you're out&#xD;
of shape and a little stressed out, but even in that case the&#xD;
pharmaceutical industry might concede the chase after that&#xD;
particular&#xD;
bit of revenue.&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; But when the insurance industry runs advertising&#xD;
campaigns to&#xD;
discredit Moore's film, that's not democracy. The imbalance&#xD;
of money&#xD;
is just too dramatic: the health industry runs somewhere&#xD;
north of a&#xD;
trillion dollars, and spends in the ballpark of three&#xD;
billion a year&#xD;
on advertising. By contrast, the production budget on Sicko was&#xD;
something like nine million. Even if you were to agree with&#xD;
every&#xD;
single point made by the insurance industry and disagree&#xD;
entirely with&#xD;
Moore, there's no way this system can be considered democratic.&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; I think we can all agree that we need a healthy&#xD;
debate about&#xD;
how to&#xD;
best restructure our healthcare system to better meet the&#xD;
needs of&#xD;
Americans. Moore is a master storyteller, and the way he&#xD;
shows the&#xD;
damage wreaked by the healthcare system in people's lives&#xD;
will make&#xD;
you weep. Getting people to sit up and care is an important&#xD;
contribution to the debate, but it isn't enough. As Lauren&#xD;
points out,&#xD;
anecdotes are not a great way to get to accurate&#xD;
information. To have&#xD;
a healthy debate, we need to be looking really intensely at the&#xD;
numbers. In a free society, the insurance companies&#xD;
absolutely should&#xD;
have the chance to present their case as well.&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; I also think it's just fine for Google to take their ad&#xD;
dollars, as&#xD;
long as we maintain the integrity of our search results.&#xD;
Those really&#xD;
&lt;i&gt;are&lt;/i&gt; democratic, and our commitment to those&#xD;
principles runs deep at&#xD;
Google, from the original PageRank algorithm to the &lt;a&#xD;
href="http://investor.google.com/founders_letter.html"&gt;Founder's&#xD;
Letters&lt;/a&gt;&#xD;
filed with the SEC, through the actions of the engineers and&#xD;
support&#xD;
staff I work with every day.&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; But, back to ads, I personally do not weep for the&#xD;
insurance&#xD;
companies, and I frankly don't think they need that much help in&#xD;
getting their message across. This opinion is one of many;&#xD;
within the&#xD;
company, there are lots of people with lots of opinions, and&#xD;
a lot of&#xD;
thought about what it means to do the right thing. Where it gets&#xD;
interesting is when there is tension between all these goals,&#xD;
especially between running a company that is "trustworthy and&#xD;
interested in the public good" as well as profitable. In&#xD;
those cases,&#xD;
we have a spirited debate.&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; In fact, I am now going to reveal one of our most&#xD;
heavily&#xD;
guarded&#xD;
corporate secrets: within Google, Godwin's Law appears to be&#xD;
suspended. Conflicts, even on really sensitive and&#xD;
contentious topics,&#xD;
tend to get treated as misunderstandings and resolved,&#xD;
rather than&#xD;
degenerating into flamewars.&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; I don't know that we'll always do the right thing as a&#xD;
company, but I&#xD;
do have great faith that we will try our best to figure out&#xD;
what that&#xD;
is. I also know that when I see something wrong, I'll take a&#xD;
stand.&#xD;
This is not just me, but, believe it or not, is enshrined as&#xD;
principle I(d) in our &lt;a&#xD;
href="http://investor.google.com/conduct.html"&gt;Code of&#xD;
Conduct&lt;/a&gt;.&#xD;
For a moneymaking outfit in corporate America today, that's&#xD;
actually&#xD;
pretty amazing, and good enough for me personally. I'm also&#xD;
going to be spending some time over the next few weeks&#xD;
learning about healthcare initiatives within Google, such as&#xD;
&lt;a&#xD;
href="http://googleblog.blogspot.com/2007/06/is-there-doctor-in-family.html"&gt;Dr.&#xD;
Roni Ziegler's work&lt;/a&gt;.&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; I'd go so far as to say that if the public debates about&#xD;
important&#xD;
issues like healthcare were as well-informed and considerate&#xD;
as the&#xD;
internal discussions I've seen so far at Google, then&#xD;
Michael Moore&#xD;
probably never would have felt the need to make the film&#xD;
Sicko. That&#xD;
would have been something of a shame, because, like Picasso's&#xD;
Guernica, Moore has made great art from the raw material of&#xD;
human&#xD;
suffering on a large scale. Go see it. (*)&#xD;
&#xD;
&lt;p&gt; &lt;p&gt; &lt;p&gt; *Like everything else in this blog, the movie review&#xD;
represents my&#xD;
personal opinion and does not in any way represent Google's&#xD;
official&#xD;
corporate policy.</description>
    </item>
    <item>
      <pubDate>Tue, 19 Jun 2007 21:02:09 GMT</pubDate>
      <title>19 Jun 2007</title>
      <link>http://www.advogato.org/person/raph/diary.html?start=414</link>
      <guid>http://www.advogato.org/person/raph/diary.html?start=414</guid>
      <description>&lt;b&gt;Advogato talk&lt;/b&gt;&#xD;
&#xD;
&lt;p&gt; I'm giving a talk on Advogato at Google on the evening of&#xD;
Monday the 25th. It's open to the public - all Advogatans&#xD;
who are in the area are welcome.&#xD;
&#xD;
&lt;p&gt; Here's the &lt;a&#xD;
href="http://google-code-updates.blogspot.com/2007/06/open-source-developers-google-speaker_15.html"&gt;talk&#xD;
info&lt;/a&gt;. It will be videotaped, so if it's not convenient&#xD;
to the area, you'll probably be able to see video too.&#xD;
</description>
    </item>
    <item>
      <pubDate>Sat, 5 May 2007 08:33:10 GMT</pubDate>
      <title>5 May 2007</title>
      <link>http://www.advogato.org/person/raph/diary.html?start=413</link>
      <guid>http://www.advogato.org/person/raph/diary.html?start=413</guid>
      <description>&lt;b&gt;Curves&lt;/b&gt;&#xD;
&#xD;
&lt;p&gt; I've been silent for a long time, but am getting ready to do&#xD;
a real release of my curve editing tools.&#xD;
&#xD;
&lt;p&gt; In the meantime, under the philosophy of "release early,&#xD;
release often," there's a very rough release up at the new&#xD;
&lt;a href="http://levien.com/spiro/" &gt;Spiro&lt;/a&gt; page, as well&#xD;
as a darcs repository. Brave souls are encouraged to try it&#xD;
out, and of course patches are welcome (it's all GPL).&#xD;
&#xD;
&lt;p&gt; The timing is, coincidentally, in time for Dave Crossland's&#xD;
talk at &lt;a&#xD;
href="http://www.libregraphicsmeeting.org/"&gt;LGM&lt;/a&gt;. He will&#xD;
be doing a demo, and is encouraging people to integrate the&#xD;
core technology with other projects like Inkscape.&#xD;
&#xD;
&lt;p&gt; &lt;b&gt;PhD&lt;/b&gt;&#xD;
&#xD;
&lt;p&gt; If I am oddly quiet and rudely unresponsive, it is because I&#xD;
am trying to finish my PhD thesis - I really want to get a&#xD;
draft to my readers by May 21, which is of course very soon.&#xD;
Fortunately, I have a lot of it done. Even so, my goal is to&#xD;
spend most days doing nothing but writing and drawing figures.&#xD;
&#xD;
&lt;p&gt; Thanks for your understanding.&#xD;
</description>
    </item>
    <item>
      <pubDate>Sat, 11 Nov 2006 22:22:00 GMT</pubDate>
      <title>11 Nov 2006</title>
      <link>http://www.advogato.org/person/raph/diary.html?start=412</link>
      <guid>http://www.advogato.org/person/raph/diary.html?start=412</guid>
      <description>&lt;b&gt;Lots of stuff&lt;/b&gt;&#xD;
&#xD;
&lt;p&gt; Hi all! I've been fairly inwardly focussed for the past few&#xD;
months, but there's a lot of stuff happening now, and I'm&#xD;
feeling more like reaching out to the world. Usually this&#xD;
time of year I start feeling like I want to hibernate, what&#xD;
with the evenings getting dark and the rain beginning, but&#xD;
this time I seem to have even more energy than usual.&#xD;
&#xD;
&lt;p&gt; &lt;b&gt;A tough logic puzzle&lt;/b&gt;&#xD;
&#xD;
&lt;p&gt; Do you like difficult puzzles? Wanna show off your&#xD;
brilliance to the rest of the world and make a little money&#xD;
to boot? Take a look at Ghostscript &lt;a&#xD;
href="http://bugs.ghostscript.com/show_bug.cgi?id=688990"&gt;bug&#xD;
688990&lt;/a&gt;. I spent more than a week trying to reverse&#xD;
engineer the imagemask interpolation algorithm used by Adobe&#xD;
PostScript, based on the original Mac implementation from&#xD;
twenty or so years ago, but was only able to come up with an&#xD;
approximate answer.&#xD;
&#xD;
&lt;p&gt; Feel free to post comments, questions, or requests for more&#xD;
test images to the bug itself. The "bountiable" keyword&#xD;
means that the solution (hopefully implemented as code) gets&#xD;
a check for, I think, $500.&#xD;
&#xD;
&lt;p&gt; &lt;b&gt;Fonts&lt;/b&gt;&#xD;
&#xD;
&lt;p&gt; My font releases are moving forward. &lt;a&#xD;
href="http://levien.com/type/myfonts/inconsolata.html"&gt;Inconsolata&lt;/a&gt;,&#xD;
in particular, is just about done, and that's now released&#xD;
under the new SIL Open Font License. There are a few other&#xD;
goodies posted on my font pages, for people who haven't seen&#xD;
them in a while.&#xD;
&#xD;
&lt;p&gt; &lt;b&gt;Geometry&lt;/b&gt;&#xD;
&#xD;
&lt;p&gt; I met &lt;a href="http://njhurst.com/" &gt;Nathan Hurst&lt;/a&gt; about&#xD;
six years ago when I gave a talk at linux.conf.au. We&#xD;
chatted about Libart, then pretty much went our separate&#xD;
ways since then.&#xD;
&#xD;
&lt;p&gt; Libart, as you'll recall, was the graphics library behind &lt;a&#xD;
href="http://www.levien.com/svg/"&gt;Gill&lt;/a&gt;, which begat &lt;a&#xD;
href="http://www.sodipodi.com/index.php3"&gt;Sodipodi&lt;/a&gt;.&#xD;
Sodipodi, in turn, begat &lt;a&#xD;
href="http://www.inkscape.org/"&gt;Inkscape&lt;/a&gt;, which is&#xD;
starting to draw a lot of attention and users. In any case,&#xD;
Inkscape now uses Cairo for the rendering, but the&#xD;
vector-based geometry operations are still somewhat messy&#xD;
and ad-hoc, so Nathan and others have founded the &lt;a&#xD;
href="http://wiki.inkscape.org/wiki/index.php/Lib2geom"&gt;lib2geom&lt;/a&gt;&#xD;
project to address those needs.&#xD;
&#xD;
&lt;p&gt; As it turns out, I have both interest in and need of these&#xD;
kinds of basic computational geometry primitives for my font&#xD;
work, especially stroke offset, intersection (for making&#xD;
nice clean outlines), and conversion to optimized Beziers. I&#xD;
have various prototypes written in Python and so on, and&#xD;
have sent those to Nathan.&#xD;
&#xD;
&lt;p&gt; With luck, all of this stuff will come together as&#xD;
efficient, robust C++ code, and then my dream of having a&#xD;
good implementation of next-generation font tools will be&#xD;
that much closer. I'm also hopeful that, by joining forces&#xD;
with Nathan and others on the lib2geom project, Inkscape and&#xD;
other vector-based free software projects can benefit.&#xD;
&#xD;
&lt;p&gt; &lt;b&gt;Spam&lt;/b&gt;&#xD;
&#xD;
&lt;p&gt; It looks like the new spam filter here is working&#xD;
swimmingly. I've long felt that the trust metric ideas were&#xD;
sound, but that they needed more time and energy on their&#xD;
implementation than they were getting. Looks like Steve is&#xD;
doing a great job on that, and I hope that the success here&#xD;
inspires other people as well.&#xD;
&#xD;
&lt;p&gt; One project people might want to take a look at is the &lt;a&#xD;
href="http://bitchun.org/"&gt;Bitchun Society&lt;/a&gt;, by Joseph&#xD;
Petviashvili. It basically implements a similar eigenvalue&#xD;
trust metric as the diary rankings here, but as a Jabber&#xD;
bot. I don't really know whether this particular&#xD;
implementation has the mojo to really take off, but the more&#xD;
trust metric toys there are out there to play with and learn&#xD;
from, the better.&#xD;
&#xD;
&lt;p&gt; &lt;b&gt;Other social connections&lt;/b&gt;&#xD;
&#xD;
&lt;p&gt; I've been busy in lots of other ways too. Last night I had&#xD;
dinner with Till Kamppeter and a hundred or so other Ubuntu&#xD;
developers. We're working toward merging ESP Ghostscript&#xD;
into the main Ghostscript repository, something which our&#xD;
move to GPL-only licensing was meant to enable. We have a&#xD;
few details to iron out, but I'm very hopeful about improved&#xD;
user experience people should see as a result.&#xD;
&#xD;
&lt;p&gt; &lt;b&gt;Election&lt;/b&gt;&#xD;
&#xD;
&lt;p&gt; Last Tuesday I worked as an election judge (fancy name for&#xD;
pollworker) at a precinct up the hill in Berkeley. I've&#xD;
become pretty cynical about the political process, and&#xD;
participating in this civic ritual at the neighborhood level&#xD;
was a great anodyne to that cynicism.&#xD;
&#xD;
&lt;p&gt; I signed up largely out of concern for the mischief&#xD;
potential of all these fancy new voting machines. As it&#xD;
happened, our Sequoia &lt;a&#xD;
href="http://sequoiavote.com/productguide.php?product=INSIGHT&amp;type=Introduction"&gt;Optech&#xD;
Insight&lt;/a&gt; jammed about three hours into the election, so&#xD;
we were back to putting paper ballots into a ballot-box,&#xD;
essentially stone-age technology. Most people seemed happy&#xD;
with that, and I'm pleased to report that our precinct was&#xD;
able to account for all but one of the 800+ pieces of paper&#xD;
we started with, at the end of our 14-hour day.&#xD;
&#xD;
&lt;p&gt; My faith in democracy is much restored. I can heartily&#xD;
recommend working at the polls to fellow Advogatans. It's a&#xD;
great way to become more involved with your community and&#xD;
your country.&#xD;
</description>
    </item>
    <item>
      <pubDate>Wed, 7 Jun 2006 18:14:37 GMT</pubDate>
      <title>7 Jun 2006</title>
      <link>http://www.advogato.org/person/raph/diary.html?start=411</link>
      <guid>http://www.advogato.org/person/raph/diary.html?start=411</guid>
      <description>&lt;b&gt;Ghostscript leading edge is now GPL!&lt;/b&gt;

&lt;p&gt; I have some great news to report. The leading edge of Ghostscript
development is now under GPL license, as is the latest 
release, &lt;a href="http://sourceforge.net/project/showfiles.php?group_id=1897&amp;package_id=108733" &gt;Ghostscript 8.54&lt;/a&gt;.

&lt;p&gt; By switching to the GPL, we're reaffirming our commitment to the free
software world. One big reason for this decision was to reduce the
lead time between bugs being fixed in the development tree and users
seeing the fixes, especially those users dependent on Linux
distributions.

&lt;p&gt; Moving forward, we'd also like to resolve the effective fork with "ESP
Ghostscript," so that our development tree is suitable directly for
use in Linux distributions without a lot of extra patches. It would be
very nice if all the GPL patches could be incorporated into the main
tree without any license restrictions (which means that we need
copyright assignment), but realistically, we'll still have to
implement an apartheid system of some kind, so that a GPL-only
subdirectory exists that gets deleted out of our commercial releases.

&lt;p&gt; As &lt;a href="http://www.advogato.org/person/rillian/" &gt;Raph Giles&lt;/a&gt; has &lt;a
href="http://www.advogato.org/person/rillian/diary.html?start=80"&gt;posted&lt;/a&gt;
recently, we're looking for a person to oversee this integration work,
and to work more closely with the distributions and others in the free
software community. Please let either of us know if you're
interested. This might also be a good time to remind people of our "&lt;a
href="http://www.ghostscript.com/article/32.html"&gt;bug bounty&lt;/a&gt;"
program, which pays a nice little bonus for fixing bugs in our tracker
marked with the "&lt;a href="http://bugs.ghostscript.com/buglist.cgi?keywords_type=allwords&amp;keywords=bountiable&amp;bug_status=UNCONFIRMED&amp;bug_status=NEW&amp;bug_status=ASSIGNED&amp;bug_status=REOPENED" &gt;bountiable&lt;/a&gt;" keyword.

&lt;p&gt; We haven't been getting a lot of development work from the free
community recently, but we continue to get extremely valuable testing,
patching, and other quality assurance. Thanks again to everybody in
the community for this - it's much appreciated, and putting our
leading edge development branch into GPL is one way of saying "thank
you." I'm excited about the potential for working more closely with
people in the free software world.
</description>
    </item>
    <item>
      <pubDate>Wed, 24 May 2006 16:26:45 GMT</pubDate>
      <title>24 May 2006</title>
      <link>http://www.advogato.org/person/raph/diary.html?start=410</link>
      <guid>http://www.advogato.org/person/raph/diary.html?start=410</guid>
      <description>&lt;b&gt;WinHEC&lt;/b&gt;

&lt;p&gt; I'm posting this from our booth at WinHEC in Seattle, having just seen the keynote by Bill Gates. There's lots of cool technology and devices, but overall I got the sense of a totalitarian vision, no more so than in the "&lt;a href="http://www.microsoft.com/whdc/flexgo/default.mspx" &gt;FlexGo&lt;/a&gt;" initiative designed for developing countries, in which people don't buy so much as rent PC's, and rely on a DRM-mode access control system that shuts the computer off if they don't pay.

&lt;p&gt; A lot of the stuff they showed at the keynote has to do with reducing the amount of manual configuration necessary. A lot of Windows Rally seems to be playing catch-up with Bonjour (formerly Rendezvous, and closely related to zeroconf, which is slowly but surely getting implemented in the free space). I think there's a lot of potential in this space, especially for first-principles research digging into the question of how much manual configuration is truly needed, as opposed to piling hack upon hack.

&lt;p&gt; Even though this is a Windows-centric conference, there are some developers who really grok the cross-platform and open source worlds. One app (which has asked not to be named) uses WxWidgets, and they're even considering OCaml. One of the main things holding them back from that would be the wx bindings, which currently only exist in very crude form. That's got me thinking again about choice of languages, and I'll probably be blogging about that. Among other things, I should take another look at wx to see whether it's Good Enough(tm) to build the cross-platform GUI stuff I need, or whether I should keep going with my own very lightweight C abstraction layer (check out the &lt;a href="http://raph.levien.com/garden/x3/" &gt;darcs repo&lt;/a&gt; if you want to play with it).

&lt;p&gt; &lt;b&gt;High DPI&lt;/b&gt;

&lt;p&gt; One of the features promised for Vista is support for high-dpi displays. In the December beta of Vista, I played with setting the dpi to 192, and the results were terrible - in many cases, fonts were scaled doubly, once by being sensitive to the dpi setting, and again by the compatibility-mode scaling. The February beta was a lot better, so it's possible that it will kinda sorta work by the time Vista ships. That said, Samsung is here showing their family of flat panels, and none of their panels push dpi past what was widely available a couple years ago.

&lt;p&gt; Apple has also been making various noises about high-dpi applications, most notably David Hyatt's &lt;a "href=http://webkit.opendarwin.org/blog/?p=55"&gt;blog entry&lt;/a&gt; on high-dpi web sites. There are all kinds of crufty ways of detecting whether the browser is high-dpi, based on CSS3 selectors and so on, but there's no clean simple way to do it.

&lt;p&gt; David obviously can't say much about Apple's future product plans, but you can probably read between the lines when he mentions his Dell laptop with 1900x1200 (145dpi) resolution, not to mention the fact that he's working on this stuff at all. Apple is in a good position to innovate here - it would fit the pattern they set with 802.11, FireWire, combo drives, and more than a few other things.
</description>
    </item>
    <item>
      <pubDate>Sat, 15 Apr 2006 21:29:16 GMT</pubDate>
      <title>15 Apr 2006</title>
      <link>http://www.advogato.org/person/raph/diary.html?start=409</link>
      <guid>http://www.advogato.org/person/raph/diary.html?start=409</guid>
      <description>&lt;b&gt;Travel&lt;/b&gt;

&lt;p&gt; I had a great time in the Netherlands - both working and having fun. A highlight of the trip was meeting great people like Dave Crossland (minimal web presence) and &lt;a href="http://blog.japj.net/" &gt;Jeroen Janssen&lt;/a&gt;.

&lt;p&gt; &lt;b&gt;Curves&lt;/b&gt;

&lt;p&gt; There are a number of basic algorithms needed for any serious curve application, including stroke offset, intersection, and conversion to lower-level operations for rendering. The standard representation for curves is, of course, piecewise (cubic) Beziers, and in this representation the implementation of all these basic algorithms is reasonably well understood.

&lt;p&gt; However, these problem can't yet be considered solved in the free software world, because there is a lot of software out there that implements them badly (including &lt;a href="http://fontforge.sourceforge.net/" &gt;FontForge&lt;/a&gt;, which I'd really like to see improved), and there isn't a really good library out there that you can just call. Rendering, yes, Beziers make that really simple. Stroke offset and intersection, though, are considered pretty difficult in the Bezier formulation. Offset, in particular, has a well-deserved reputation for being numerically tricky when starting from Beziers. See &lt;a href="http://digitalmedia.yonsei.ac.kr/papers/compare.pdf" &gt;Comparing Offset Curve Approximation Methods&lt;/a&gt; for a pretty good survey of the problem.

&lt;p&gt; I've been spending lots of time with other curve representations, including the clothoid (spiral of Cornu). My main motivation has been to make a better UI for editing curves, but I'm starting to get the sense that they may be better for the under-the-hood tasks as well. While in the Netherlands, I worked out a closed-form equation (in Cesaro form) for offset curves of the Cornu spiral, and am inclined to believe that it's both simpler to code and likely to give better results (speed, robustness, accuracy) than previous methods.

&lt;p&gt; I'm blogging this partly to test the waters for a collaboration. I can see that happening in a few different ways. Maybe there's someone out there who really needs a solution to problems like stroke offset, and is willing to consider a new approach rather than a rehash of existing techniques. Alternatively, there might be a bright student or two who really want to stretch their numerical and computational geometry skills, and want to work with a mentor who's put a lot of thought into the problem. Either way, the result is likely to be a journal paper and a codebase published under a nice free software license.

&lt;p&gt; &lt;b&gt;Xara&lt;/b&gt;

&lt;p&gt; Dave showed me screenshots and so on from &lt;a href="http://www.xaraxtreme.org/" &gt;Xara&lt;/a&gt;, for which the source code has just been released. I tried building it on Ubuntu Breezy, but ran into just enough make problems to run out of patience. Even so, it looks very interesting. I was getting something of a "too good to be true" vibe from the preannouncements, but now the code is out there, and the people behind it are showing up at free software events like the &lt;a href="http://andy.brisgeek.com/archives/11" &gt;Libre Graphics Meeting&lt;/a&gt;. This project looks like it may well transform the landscape for free 2D graphics tools.
</description>
    </item>
    <item>
      <pubDate>Thu, 9 Mar 2006 19:46:53 GMT</pubDate>
      <title>9 Mar 2006</title>
      <link>http://www.advogato.org/person/raph/diary.html?start=408</link>
      <guid>http://www.advogato.org/person/raph/diary.html?start=408</guid>
      <description>&lt;b&gt;Latin&lt;/b&gt;

&lt;p&gt; I'm citing this 1744 &lt;a href="http://math.dartmouth.edu/~euler/pages/E065.html" &gt;book&lt;/a&gt; by Leonhard Euler in my thesis chapter on the elastica, and need the following bit of Latin translated into English. Anyone out there who can handily read this, or recommend someone else who can?

&lt;p&gt; &lt;blockquote&gt;ut, inter omnes curvas ojusdem longitudinus, qu\ae\ non solum per
puncta A \&amp;amp; B transeant, sed etiam in his punctis a rectis positione
datis tangantur, definatur ea in qua sit valor hujus expressionis
$\int {ds \over RR}$ minimus.
&lt;/blockquote&gt;

&lt;p&gt; I have a pretty good idea what it says, but don't trust my own ability to get all the cases and so on correct. And some of the words don't seem entirely standard to me. "ojusdem"?

&lt;p&gt; &lt;b&gt;Netherlands&lt;/b&gt;

&lt;p&gt; I'll probably be spending the first couple of weeks of April in Venlo, the Netherlands, visiting a customer site. It might be cool to meet up with some free software hackers and font people in the area.

&lt;p&gt; To follow up on either (or both) of these, my best email address is &amp;lt;firstname&amp;gt;.&amp;lt;lastname&amp;gt;@gmail.com.

&lt;p&gt; &lt;b&gt;LTNB&lt;/b&gt;

&lt;p&gt; I have really fallen out of the habit of blogging, but I haven't exactly been a hermit like many of my other blogging lulls. I've been meeting up with quite a few people who have come through town (&lt;a href="http://www.advogato.org/person/tor/" &gt;tor&lt;/a&gt; is here now), and generally keeping quite busy. Work, in particular, is hopping right now.</description>
    </item>
    <item>
      <pubDate>Sun, 29 Jan 2006 07:21:36 GMT</pubDate>
      <title>29 Jan 2006</title>
      <link>http://www.advogato.org/person/raph/diary.html?start=407</link>
      <guid>http://www.advogato.org/person/raph/diary.html?start=407</guid>
      <description>&lt;b&gt;I come not only to bury auto*, but to praise it&lt;/b&gt;

&lt;p&gt; I'm not at all surprised by the defenses of auto* in response to my rather
harsh &lt;a href="http://www.advogato.org/person/raph/diary.html?start=406" &gt;criticism&lt;/a&gt;.

&lt;p&gt; &lt;a
href="http://www.advogato.org/person/cinamod/diary.html?start=97"&gt;Dom
Lachowicz&lt;/a&gt; writes: &lt;i&gt;I've yet to see a build system that attempted
to fill auto*'s niche and fill it as well as auto* currently does.&lt;/i&gt;
I agree completely, and perhaps my praise was simply too faint. The
goal of making software building Just Work on a wide
variety of Unix-like systems is extremely noble, and until auto*, it
wasn't even obvious that it could be done.

&lt;p&gt; I'd like to amplify even more. A lot of good free software is inspired
by the existence of good proprietary software, in the sense that Gimp
was inspired by Photoshop. If nothing else, the proprietary software
represents an existence proof that it is possible to attain those
goals.

&lt;p&gt; I think this story applies somewhat to version control systems. We've
had consensus for a very long time that CVS needed improvement and
probably replacement, but it wasn't really until BitKeeper came along
that the lightweight distributed version control systems (such as
arch, darcs, and mercurial) started coming out of the woodwork.

&lt;p&gt; Now, in the proprietary platform space, build systems are very slick,
but none of them give a rat's ass about portability to other
platforms. To the contrary, the nicer an IDE is to work in, the less
likely the developer is to escape the golden handcuffs. Lock-in is the
highest goal. If we're going to create a much better build system, we have to look to ourselves for the inspiration, because we're not going to find it anywhere else. auto* was the first great existence proof, and I think it is high time for others.

&lt;p&gt; &lt;a
href="http://www.advogato.org/person/atai/diary.html?start=31"&gt;Andy Tai&lt;/a&gt;
and others call for incremental improvement to auto*, including a
gradual phase-out of M4, but, with &lt;a href="http://www.advogato.org/person/freetype/diary.html?start=29" &gt;David Turner&lt;/a&gt;, I'm
not sure that's really feasible. I believe a program of incremental
improvement to auto* will never &lt;i&gt;really&lt;/i&gt; be able to reduce the
overall system complexity. And I do believe that a much simpler
system is possible, especially without the demands of adhering to M4,
least-common-denominator make, and least-common-denominator shell.

&lt;p&gt; I admit I did overstate some of my original points for the sake of
rhetoric. There are, indeed, good reasons to use other compilers than
the GNU toolchain. &lt;a href="http://www.advogato.org/person/rillian/diary.html?start=76" &gt;Ralph Giles&lt;/a&gt; takes me to task for not
acknowledging the importance of Solaris, but for the applications I'm personally most interested in building (font editors and the like), these vendor Unices are vastly less important than native Win32 support.

&lt;p&gt; Dom writes: &lt;i&gt;Regarding auto*'s tendency to work around deficiencies
in ld/cc/nm/etc..., all I can counter with is "we don't control the
horizontal and the vertical".&lt;/i&gt; In response, I ask: Who does? Bill
Gates? Maybe after he figures it out we can try to clone it?

&lt;p&gt; I'm not calling for violent overthrow of the auto* hegemony. I am
calling for:

&lt;p&gt; &lt;ul&gt;

&lt;p&gt; &lt;li&gt;A profusion of prototypes of new autoconfiguring build systems,
much like the distributed version control systems we've seen come out
in the last couple years or so.

&lt;p&gt; &lt;li&gt;A careful look at which aspects of make/ld/package managers/etc
are holding us back, and clear goals enunciated about how they might
be fixed.

&lt;p&gt; &lt;li&gt;A more quantitative approach to thinking about building, perhaps
empirically measured in challenges, where students are forced to use
the tools to build and package a trivial app for Linux, Mac, and
Windows platforms, and entries are scored based on time taken, defects
in the results, and so on.

&lt;p&gt; &lt;/ul&gt;

&lt;p&gt; I've had a strong enough long-term interest in this field that I am
likely to make one such prototype myself. One reason I'm blogging
about now is to gauge the waters, to figure out whether there are
other people thinking along similar lines, or whether I'm pretty much
just pissing into the wind as far as the broader free software
community.

</description>
    </item>
    <item>
      <pubDate>Wed, 18 Jan 2006 08:27:38 GMT</pubDate>
      <title>18 Jan 2006</title>
      <link>http://www.advogato.org/person/raph/diary.html?start=406</link>
      <guid>http://www.advogato.org/person/raph/diary.html?start=406</guid>
      <description>&lt;b&gt;auto* delenda est&lt;/b&gt;

&lt;p&gt; David Turner (&lt;a href="http://www.advogato.org/person/freetype/" &gt;freetype&lt;/a&gt;)'s recent &lt;a href="http://www.advogato.org/person/freetype/diary.html?start=26" &gt;post&lt;/a&gt; in response to &lt;a href="http://www.advogato.org/person/titus/diary.html?start=150" &gt;titus&lt;/a&gt; reminded me of my own auto* aversion. In sum, I think auto* represents everything that is bad about a free software project.

&lt;p&gt; Don't get me wrong, auto* was (and still is) a tremendous improvement over the bad old days of hand-editing makefiles just to have a chance of having your software build. But it is well past time to have designed, implemented, and deployed a better alternative, and I don't see too many good signs of that.

&lt;p&gt; What's wrong with it? Let me enumerate the ways:

&lt;p&gt; 1. It's way too complicated. Good software and free software, not to mention good free software, run on simplicity. auto* does not have this quality.

&lt;p&gt; 2. It's implemented in bad languages. One bad language would be enough, but M4, (portable) make, &lt;i&gt;and&lt;/i&gt; portable shell? There's a good reason nobody else has even attempted writing an app in that combination of languages.

&lt;p&gt; 3. Original goals are no longer very relevant. In the bad old days, there were lots of vendor Unices and other strange build environments. Today, in the *nix world, there is just the GNU toolchain. The amount of actual diversity that needs to be configured around is minimal.

&lt;p&gt; 4. It doesn't solve real-world portability problems. For many users, getting programs to build on Windows is at least as important as compiling on an ancient MIPS running Ultrix, yet auto* isn't much help at the former.

&lt;p&gt; 5. Bad error reporting. In "configuration science", one of the overriding goals should be production of clear and meaningful error messages.

&lt;p&gt; 6. Lack of overall systems thinking. Much of what auto* does is work around limitations in tools such as sh, make, ld, package managers, and the like. If some of these other components are better places to solve configuration and build problems, let's do it there rather than twisting ourselves into pretzels trying to work around them. Apple had the guts to extend ld in several important ways, including two-level namespace support. Why are we still stuck with the clunky late-'80s approach copied from old vendor Unices?

&lt;p&gt; It's been clear for a long time that CVS needed replacing, and now we have a variety of great alternatives, some of exhibit that classic, simple, do-one-thing-and-do-it-well free software philosophy. We should have something similar for the problems that auto* solves.

&lt;p&gt; &lt;b&gt;Japan&lt;/b&gt;

&lt;p&gt; I find myself posting from Japan once again. Why is it that I'm more likely to find a free moment here than back at home in Berkeley? Anyway, it's nice and cold, and I even got to see some snow up north in Matsumoto.
</description>
    </item>
  </channel>
</rss>
