My mother-in-law gave me fabric money for my birthday - what a treat! I ordered a pretty bundle I've been eyeing from purl soho and it arrived this week. I was not disappointed. This combo will make such an adorable baby girl quilt. I'm going to take my mom's advice and use a eyelet trim around the edge for a bit of extra girliness. Now all I need to do is learn how to quilt!
women clipart, women artist, digital women planner, digital women com daily, digital women printables, digital woman, digital women art, 3d women
Friday, 25 May 2007
Wednesday, 23 May 2007
Recipe: Fresh Strawberry Lemonade
Tonight I hosted book club and my lemonade was pretty tasty. Here is the recipe:
1 cup fresh squeezed lemon juice
3/4 cup pureed fresh strawberries
1 cup sugar
6 cups water
1 cup fresh squeezed lemon juice
3/4 cup pureed fresh strawberries
1 cup sugar
6 cups water
Monday, 21 May 2007
Amazingly bad APIs
I actually don't hate the Java language (at least it's killing off c++), but every time I use it I'm blown away by how hostile the APIs are.
For example, let's say that we want to scale an image file. That's a fairly common thing to do, so it's probably only one line of code, right? Wrong. It turns out that they haven't even bothered to include a reasonable API for doing this. Instead, you have to take the awkward APIs that they do provide, and then write about 50 lines of code to do what you really want. This article that explains what the "right" way is.
Once the image is scaled, you'll want to save the smaller version too. Luckily, that's only a few lines of code. Of course that's only if you're happy with the default settings -- what if you want to use a different JPEG quality level? Here are the docs -- see if you can figure it out (the solution involves 4 additional classes).
For comparison, here is some Python code which loads an image, scales it, and then saves it at a non-default quality level:
How did this happen? My theory is that the people who made the Java APIs just sat in a room making stuff up (and possibly drawing UML diagrams). Meanwhile, the Python people were actually writing software and creating libraries to make their life easier.
There is a lesson in this: If you are building a platform, you should also be writing applications for that platform, and the platform should be designed to make life very simple for those apps. It's my understanding that Ruby on Rails came out of a process such as this (they extracted the common tasks out of their web apps). If you just sit around staring at the clouds while writing your APIs, you'll probably end up with something bad.
I also have a second theory about what happened to Java: it attracted people who like to write piles of code filled with endless abstractions. When I worked at Google, one of the engineers on our Java mailing list suggested that we ban the keyword 'new'! I was puzzled by this suggestion, but after a little research I learned that one of the hot fashions in Java is to use factories instead of 'new' (not that factories are bad, but "sometimes good" does not imply "always best"). Better yet, you don't reference the factories directly (not enough abstraction), instead you have some framework that injects the factories into your classes according to what is written in an XML configuration file. In this way, you can make your code perfectly unreadable, but more importantly, it is very abstract.
Update: Several people have interpreted this post to mean that I'm opposed to the factory pattern. That is, of course, silly. Factories, when the situation calls for them, are fine. For example, the python code above is using a factory. What harms code is the blanket application of the factory pattern in every possible situation. To put this another way, Tabasco sauce is delicious on eggs, but I still don't put it on ice cream. (but don't think I haven't tried!)
Update Two: It's not about Java, really! My point here is that your APIs should emerge from the needs of real applications, and that they should make common tasks super-easy. Bad APIs are common in many languages, Java just happens to be the language that I'm using right now.
Why didn't I simply hunt down+install some third-party image library? Because that's a hassle too (probably more work than copying code off of some web page), and all I want is to generate nice looking thumbnails.
For example, let's say that we want to scale an image file. That's a fairly common thing to do, so it's probably only one line of code, right? Wrong. It turns out that they haven't even bothered to include a reasonable API for doing this. Instead, you have to take the awkward APIs that they do provide, and then write about 50 lines of code to do what you really want. This article that explains what the "right" way is.
Once the image is scaled, you'll want to save the smaller version too. Luckily, that's only a few lines of code. Of course that's only if you're happy with the default settings -- what if you want to use a different JPEG quality level? Here are the docs -- see if you can figure it out (the solution involves 4 additional classes).
For comparison, here is some Python code which loads an image, scales it, and then saves it at a non-default quality level:
from PIL import ImageDoing the same thing in Java requires closer to 100 lines, not because the language is bad, but because the APIs are terrible.
i = Image.open("/tmp/c.jpg")
i.thumbnail([220, 133], Image.ANTIALIAS)
i.save('/tmp/c-thumb.jpg', quality=90)
How did this happen? My theory is that the people who made the Java APIs just sat in a room making stuff up (and possibly drawing UML diagrams). Meanwhile, the Python people were actually writing software and creating libraries to make their life easier.
There is a lesson in this: If you are building a platform, you should also be writing applications for that platform, and the platform should be designed to make life very simple for those apps. It's my understanding that Ruby on Rails came out of a process such as this (they extracted the common tasks out of their web apps). If you just sit around staring at the clouds while writing your APIs, you'll probably end up with something bad.
I also have a second theory about what happened to Java: it attracted people who like to write piles of code filled with endless abstractions. When I worked at Google, one of the engineers on our Java mailing list suggested that we ban the keyword 'new'! I was puzzled by this suggestion, but after a little research I learned that one of the hot fashions in Java is to use factories instead of 'new' (not that factories are bad, but "sometimes good" does not imply "always best"). Better yet, you don't reference the factories directly (not enough abstraction), instead you have some framework that injects the factories into your classes according to what is written in an XML configuration file. In this way, you can make your code perfectly unreadable, but more importantly, it is very abstract.
Update: Several people have interpreted this post to mean that I'm opposed to the factory pattern. That is, of course, silly. Factories, when the situation calls for them, are fine. For example, the python code above is using a factory. What harms code is the blanket application of the factory pattern in every possible situation. To put this another way, Tabasco sauce is delicious on eggs, but I still don't put it on ice cream. (but don't think I haven't tried!)
Update Two: It's not about Java, really! My point here is that your APIs should emerge from the needs of real applications, and that they should make common tasks super-easy. Bad APIs are common in many languages, Java just happens to be the language that I'm using right now.
Why didn't I simply hunt down+install some third-party image library? Because that's a hassle too (probably more work than copying code off of some web page), and all I want is to generate nice looking thumbnails.
Tuesday, 15 May 2007
Jam Season
I made my first batch of strawberry last night - so yummy. Now that I know where to order fruit pectin online, I can't wait to try blackberry, raspberry, boysenberry, mixed berry...
Sunday, 13 May 2007
to my Mom...
Happy Mother's Day! I sure do love you. Thank you for all your support and encouragement throughout my life. You always defended me, even when I didn't deserve it. You stuck my my side during my craziest years, often acting my voice of reason. You tried your best to keep me level headed and focused on what is really important, and because of that, I feel like I owe most of my accomplishments to your advice and better judgment.
For the last four years, I have had another special lady in my life. Verlene, you are the kind of mother-in-law a girl could only dream of. Thanks for all of your love and friendship, and for raising such a wonderful son. I feel lucky to be a part of your family.
For the last four years, I have had another special lady in my life. Verlene, you are the kind of mother-in-law a girl could only dream of. Thanks for all of your love and friendship, and for raising such a wonderful son. I feel lucky to be a part of your family.
I'm on a lucky streak
Back in April I won a giveaway over at Cool Mom Picks - a beautiful personalized birth necklace from LittleJules. Pretty, right?
I had a hard time getting a good, clear picture (the pendant is less than 3/4 inch square), but you get the basic idea - check out the website for much better pictures. On the front, you have your choice of baby hand or foot prints and the baby's name, and on the back they will engrave all the birth info - date, time, length and weight.
Well, it just so happens that on the same day I found out I won, my good friend had her first baby boy. Great timing, right? I really love this necklace. It is so delicate and pretty and makes the perfect gift for a new mom (hint, hint, Jared - take note of this for later).
I had a hard time getting a good, clear picture (the pendant is less than 3/4 inch square), but you get the basic idea - check out the website for much better pictures. On the front, you have your choice of baby hand or foot prints and the baby's name, and on the back they will engrave all the birth info - date, time, length and weight.
Well, it just so happens that on the same day I found out I won, my good friend had her first baby boy. Great timing, right? I really love this necklace. It is so delicate and pretty and makes the perfect gift for a new mom (hint, hint, Jared - take note of this for later).
Friday, 11 May 2007
Flash, Silverlight, and JavaFX all look nice, but what I really want is better file upload
One of the most annoying limitations when writing web apps comes from the
Here are a few of the problems with
Java applets can actually do most of these things if they are signed and the user agrees to allow the applet access to their filesystem. Unfortunately, Java applets don't actually work, and after 11 years of not working, I'm not expecting that to change. Facebook has a nice image uploader applet that lets you browse your photos locally and then scales them before uploading to make the whole thing go fast. The only problem, other than the annoying "do you want to trust this applet" prompt, is that it crashed my browser the second time I tried it.
To me, the great thing about flash is that it fills in basic capabilities missing from the browser, such is video, sound, camera and microphone access, and they did it with a reasonably small and stable browser plugin that I'm not afraid to allow onto my computer. A few months ago, I accidentally upgraded one of my computers to Flash 9 -- I don't remember how exactly, I just remember that it was simple and non-eventful.
Here's my idea: I want to create a small, reliable browser plugin that does for file uploads what flash does for audio and video. It should work with all the modern browser/os combinations, and install with minimal effort and fuss (browser restarts avoided if possible). It would be free and open source, but hosted in a common location for easy install.
Popular Ajax libraries such as jQuery, YUI, and Dojo can add support in such a way that people who don't have the plugin just get the regular browser upload control (and maybe a link to install the plugin), while those who do have the plugin get a better ui. Clearly, getting people to install a new plugin isn't easy, but once any site convinces them, their experience automatically gets better on all other sites that support the plugin. There isn't a chicken&egg problem because the plugin simply provides an enhancement to the already existing (but very poor) browser functionality, so sites can easily add support without fear of losing people who don't have the plugin (unlike building a whole app in silverlight, or whatever).
I'd like to hear from anyone with experience writing browser plugins. How difficult is the technology side of this? (making it small, reliable, and stable -- crashing browsers is not ok) Also, are you interested it writing this plugin? I'm serious about this, and willing to pay quite a bit of money to make it happen.
Here are a few more details on how I imagine the plugin working:
It would not have any in-browser UI -- it would simply be an object that can be called from javascript and that would pop open a nice file browser with thumbnails and all that (similar to windows explorer, perhaps). It would also provide upload-related utility functions, such as image resizing. Since the file access is read-only and limited to what the user selects, security shouldn't be a big problem, assuming of course that the plugin implementation is secure (and it must be).
Here is some JS illustrating how I imagine using this plugin (UploadHelper is the object provided by the plugin):
Update:
Several people have suggested that I should instead try to get this feature added to web browsers or (better yet) the web browser standards. That's a fine long-term solution, but realistically it will take years to happen. I would rather have an immediate (months, not years) fix in the form of a plugin, and then let the web browsers add it as a standard feature on their own schedule. This is somewhat similar to the path followed by XMLHTTP.
Sriram Krishnan of Microsoft makes a few good points:
Silverlight sounds pretty nice. Google or Adobe had better have an open alternative on the way, or else MS may be able to recapture the application platform.
Update Two:
I believe that within a few months we will have a few reasonable solutions to this problem!
<input type="file">
form element, which is the standard way of uploading files.Here are a few of the problems with
<input type="file">
:- You can only select a single file per input element, and there is no way to select entire folders.
- Web browsers just pop-open the standard file open dialog, which is often not very good. For example, the dialog probably just shows a list of files, not thumbnails. This can make it difficult to pick the correct file if they all have names like IMG_3485.JPG, and it's therefore easy to upload the wrong file.
- There is no way to actually read the data locally without first sending it to the server and then having the server send it back.
- There is no way to do any local processing on the data, such as scaling images to make them smaller.
Java applets can actually do most of these things if they are signed and the user agrees to allow the applet access to their filesystem. Unfortunately, Java applets don't actually work, and after 11 years of not working, I'm not expecting that to change. Facebook has a nice image uploader applet that lets you browse your photos locally and then scales them before uploading to make the whole thing go fast. The only problem, other than the annoying "do you want to trust this applet" prompt, is that it crashed my browser the second time I tried it.
To me, the great thing about flash is that it fills in basic capabilities missing from the browser, such is video, sound, camera and microphone access, and they did it with a reasonably small and stable browser plugin that I'm not afraid to allow onto my computer. A few months ago, I accidentally upgraded one of my computers to Flash 9 -- I don't remember how exactly, I just remember that it was simple and non-eventful.
Here's my idea: I want to create a small, reliable browser plugin that does for file uploads what flash does for audio and video. It should work with all the modern browser/os combinations, and install with minimal effort and fuss (browser restarts avoided if possible). It would be free and open source, but hosted in a common location for easy install.
Popular Ajax libraries such as jQuery, YUI, and Dojo can add support in such a way that people who don't have the plugin just get the regular browser upload control (and maybe a link to install the plugin), while those who do have the plugin get a better ui. Clearly, getting people to install a new plugin isn't easy, but once any site convinces them, their experience automatically gets better on all other sites that support the plugin. There isn't a chicken&egg problem because the plugin simply provides an enhancement to the already existing (but very poor) browser functionality, so sites can easily add support without fear of losing people who don't have the plugin (unlike building a whole app in silverlight, or whatever).
I'd like to hear from anyone with experience writing browser plugins. How difficult is the technology side of this? (making it small, reliable, and stable -- crashing browsers is not ok) Also, are you interested it writing this plugin? I'm serious about this, and willing to pay quite a bit of money to make it happen.
Here are a few more details on how I imagine the plugin working:
It would not have any in-browser UI -- it would simply be an object that can be called from javascript and that would pop open a nice file browser with thumbnails and all that (similar to windows explorer, perhaps). It would also provide upload-related utility functions, such as image resizing. Since the file access is read-only and limited to what the user selects, security shouldn't be a big problem, assuming of course that the plugin implementation is secure (and it must be).
Here is some JS illustrating how I imagine using this plugin (UploadHelper is the object provided by the plugin):
// Have the user choose files or directories to upload.
// Returns undefined if user clicks Cancel. Doing this with a
// callback instead of a return value would also be ok.
var files = UploadHelper.chooseFiles(
{filter:'*.jpg,*.gif,*.png', allowDirectories:true});
if (files) {
var s = 'You selected: ';
for (var f in files) {
var file = files[f];
s += (file.name + " (" +
file.imageinfo().width + "x" +
file.imageinfo().height + ", original size = " + file.size);
files[f] = file.scaleImage({maxwidth:100, maxheight:100, quality:5});
s += " scaled size = " + files[f].size + ") ";
// If I could somehow insert this image on the current web page
// too, that would be really awsome.
}
alert(s);
// using jquery XMLHTTP wrapper
$.ajax({
type: "POST",
url: "/upload",
data: UploadHelper.encode(files, 'multipart/form-data'),
contentType: 'multipart/form-data'
});
}
var files = UploadHelper.chooseFiles({filter:'*.txt'});
if (files) {
// We can also read the content of the selected file
// The ability to get chunks of a file also means that it's possible
// to restart failed uploads, and to chunk large files into multiple
// POSTs.
for (var f in files) {
var file = files[f];
var d = file.getData(0, 50); // get the first 50 bytes
if (file.size > 50) d += "...";
alert(files[f].name + ": " + d);
}
}
Update:
Several people have suggested that I should instead try to get this feature added to web browsers or (better yet) the web browser standards. That's a fine long-term solution, but realistically it will take years to happen. I would rather have an immediate (months, not years) fix in the form of a plugin, and then let the web browsers add it as a standard feature on their own schedule. This is somewhat similar to the path followed by XMLHTTP.
Sriram Krishnan of Microsoft makes a few good points:
- The standard file open dialog in windows already has a thumbnail view. Unfortunately, this feature is hidden under a completely unremarkable icon and despite having used windows for many years, I've never seen it before today. This is a great example of why simply adding a feature isn't good enough -- it also needs a good ui or else it may as well not even exist. Furthermore, not existing seems to be the status of the thumbnail view on OSX -- hopefully that will be fixed in 10.5.
- This feature request could be implemented in Silverlight. That's great news! MS should write and release a little Silverlight control that provides these functions to JS. I would be very hesitant to write (or rewrite) my apps in Silverlight, but if I could simply embed a little Silverlight module the same way that I would a flash mp3 player, then I'd definitely use that. This would be a very effective way for MS to get people started installing and using Silverlight (start with something small and optional).
Silverlight sounds pretty nice. Google or Adobe had better have an open alternative on the way, or else MS may be able to recapture the application platform.
Update Two:
I believe that within a few months we will have a few reasonable solutions to this problem!
Thursday, 10 May 2007
Prepare yourself - this may be the cutest thing ever
All you crafters out there should check out the blog, Wee Wonderfuls. The author, Hillary Lang, is super talented and generous - she has a few of her darling original patterns posted as free downloads. I can't wait to try the Wee Bunny. She also has these paper dolls to download and cut out. So, so cute. I printed them out on magnet paper and they are now adorning my refrigerator. Originally, I was going to sent them out to my sweet little nieces, but the magnet paper I bought is more fragile than I thought it would be - I think it would tear pretty easily in little hands. Until I can find some more heavy-duty magnet sheets, this pretty little set is all mine. I can think of a few big girls who might want one, too.
Wednesday, 9 May 2007
When people don't know how to change something, they often start searching for a way to justify failure, rather than thinking about how they could try doing something different to make it work.
...
If we pretend that you can teach anyone anything, we'll find out where it's not (yet) true. But if we think that when someone isn't learning it means they can't be taught, no one will even try.
...
If you take the attitude that anything is possible, you'll find that a lot of things that were previously thought impossible actually do become possible.
Page 125
Tuesday, 8 May 2007
Design Mom is so cool
Have you heard about this?
Seriously. Best thing ever. I mean, Design Mom is always amazing, but she is really out-doing herself this week. Head on over and post your comment. Good luck!
Sunday, 6 May 2007
Ellis Island
We had such a beautiful event at Ellis Island this last weekend for work. I can't take credit for much of it, but the decor was so outstanding I couldn't help but share a couple of pictures. It was so fun (and a little stressful) to be all fancy for an evening.
I've been busy
busy, busy, busy. Things have been busy at work - we had a big event on Saturday. Plus, I have been working on a few projects lately and overall, just going to bed a little earlier and skipping my late night blogging time. Hopefully I'll get back on track soon. Anyway, I wanted to finally post pictures of what I sent out in the mellow+yellow swap.
I think my favorite part was the box - I wrapped it with my favorite paper and put on a few coats of Mod Podge - I am hoping Lacey can get some extended use out of it.
I also really liked making the stitched cards. I had never really sewn on paper before, so it was fun to experiment.
I think my favorite part was the box - I wrapped it with my favorite paper and put on a few coats of Mod Podge - I am hoping Lacey can get some extended use out of it.
I also really liked making the stitched cards. I had never really sewn on paper before, so it was fun to experiment.
Thursday, 3 May 2007
Beliefs, intelligence, and failure
From the book "Hard Facts, Dangerous Half-Truths, and Total Nonsense" (via this blog, via an email from a friend):
That's a pretty important fact. It's also an excellent example of how your success is determined by your beliefs/mindset/frame. If you believe that you can't get smarter, you won't!
I searched around a bit and found another interesting quote:
Not only does a belief in fixed intelligence prevent learning, it also makes people more risk averse! It's easy to see how some cultures or micro-cultures make people successful, while others keep them mired in failure.
I expect that this same basic principle applies to most things, whether it's skills with computers or skills with people. Obviously "nature" plays some role, but beliefs, knowledge, and determination are usually more important. Furthermore, I suspect that you can learn to enjoy these activities, and that finding the fun is the key to mastering the skill.
A series of studies by Columbia University's Carol Dweck shows .... that when people believe they are born with natural and unchangeable smarts ... [they] learn less over time. They don't bother to keep learning new things.
People who believe that intelligence is malleable keep getting smarter and more skilled ... and are willing to do new things.
That's a pretty important fact. It's also an excellent example of how your success is determined by your beliefs/mindset/frame. If you believe that you can't get smarter, you won't!
I searched around a bit and found another interesting quote:
...beliefs about the nature of intelligence have a significant impact on the way they approach challenging intellectual tasks: Students who view their intelligence as an unchangeable internal characteristic tend to shy away from academic challenges, whereas students who believe that their intelligence can be increased through effort and persistence seek them out.
Students who hold an "entity" theory of intelligence agree with statements such as "Your intelligence is something about you that you can't change very much." Since they believe their intelligence is fixed, these students place high value on success. They worry that failure-or even having to work very hard at something-will be perceived as evidence of their low intelligence. Therefore, they make academic choices that maximize the possibility that they will perform well. For example, a student may opt to take a lower-level course because it will be easier to earn an A. In contrast, students who have an "incremental" theory of intelligence are not threatened by failure. Because they believe that their intelligence can be increased through effort and persistence, these students set mastery goals and seek academic challenges that they believe will help them to grow intellectually.
Not only does a belief in fixed intelligence prevent learning, it also makes people more risk averse! It's easy to see how some cultures or micro-cultures make people successful, while others keep them mired in failure.
I expect that this same basic principle applies to most things, whether it's skills with computers or skills with people. Obviously "nature" plays some role, but beliefs, knowledge, and determination are usually more important. Furthermore, I suspect that you can learn to enjoy these activities, and that finding the fun is the key to mastering the skill.
Subscribe to:
Posts (Atom)
Followers
Blog Archive
-
▼
2007
(140)
-
▼
May
(13)
- birthday fabric
- Recipe: Fresh Strawberry Lemonade
- Amazingly bad APIs
- Jam Season
- to my Mom...
- I'm on a lucky streak
- Flash, Silverlight, and JavaFX all look nice, but ...
- Prepare yourself - this may be the cutest thing ever
- When people don't know how to change something, th...
- Design Mom is so cool
- Ellis Island
- I've been busy
- Beliefs, intelligence, and failure
-
▼
May
(13)