-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathabout.html
121 lines (113 loc) · 7.33 KB
/
about.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
<html>
<head>
<title>Autocookie</title>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<meta name="description" content="" />
<meta name="keywords" content="" />
<link rel='shortcut icon' type='image/x-icon' href='static/favicon.ico' />
<meta name="viewport" content="width=device-width, initial-scale=1">
<link href="static/bootstrap/css/bootstrap.min.css" rel="stylesheet">
<link href="static/custom.css" rel="stylesheet">
</head>
<body>
<nav class="navbar navbar-inverse navbar-fixed-top">
<div class="container">
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a id="navwords" class="navbar-brand" href="index.html">Autocookie</a>
</div>
<div id="navbar" class="collapse navbar-collapse">
<ul class="nav navbar-nav pull-right">
<!--<li class="active"><a href="#">Home</a></li>-->
<li><a id="navwords" href="https://mobeets.github.io/">mobeets</a></li>
<li><a id="navwords" href="about.html">About</a></li>
<li><a href="https://github.com/mobeets/autocake"><img src="static/github.png" class="github"/></a></li>
</ul>
</div><!--/.nav-collapse -->
</div>
</nav>
<div id="header-container" class="container">
<div class="starter-template">
<h1><a id="bigtitle" href="index.html">Autocookie</a></h1>
</div>
</div>
<div class="container">
<div class="row">
<div class="col-lg-2"></div>
<div id="shop" class="col-lg-12">
<div class="row">
<span class="col-lg-offset-2 col-lg-8 about">
<p>
<h4>Why?</h4>
I used to hate following recipes while baking. Then at some point I realized how much better things tasted when I did. I even came to believe that the best ever recipe for chocolate chip cookies was printed on the back of the Toll House chocolate chips package. (I might still believe that.)
</p>
<p>
And then I saw <a href="http://sweets.seriouseats.com/2013/12/the-food-lab-the-best-chocolate-chip-cookies.html">Kenji's amazing break-down</a> of how different ingredients affect cookie attributes. (I made <a href="https://mobeets.github.io/cookies/">this</a> app to summarize his findings for quick reference.) I was impressed, but still, I didn't improvise when I made cookies. I made the same exact cookies every single time.
</p>
<p>
I'm not like Kenji: I would never bake something over and over again and manually note the effects of changing the proportions between flour and baking soda. Instead, I wanted to make something automatic—something that could tell me how much of an ingredient I could add to or subtract from a recipe before things would start to taste wrong.
</p>
<p>
<h4>So what's an Autocookie?</h4>
Autocookie collects a bunch of recipes for the same type of food—chocolate chip cookies, to start—and finds the range of acceptable ingredient ratios. To continue my flour and baking soda example, if one recipe called for 2 cups of flour and 1 tsp of baking soda, that's a ratio of 2.0 cups/tsp. If another recipe called for 1.5 cups of flour and 2 tsp of baking soda, that's a ratio of 0.75 cups/tsp. All Autocookie does, then, is suggest proportions of baking soda and flour that stay within this range of 0.75-2.0 cups/tsp. Just expand this same idea to all ingredient combinations, across multiple recipes.
</p>
<p>
<h4>Future work</h4>
Given the messiness of recipe databases, I ended up parsing my recipe ingredient lists myself. I tried the NYTimes's <a href="https://github.com/NYTimes/ingredient-phrase-tagger">ingredient phrase tagger</a>, but in my case, because I was focused on a specific type of recipes—cookies—it ended up being easier to just roll my own ingredients parser.
</p>
<p>
Though my recipe parsing is automated I decided to aim for quality over quantity (for once) and only include recipes I've sanity-checked. However, this app could be easily modified to include different types of recipes. For instructions on this, see the README <a href="https://github.com/mobeets/autocookie">here</a>. To get the recipes themselves, you'll need access to the Yummly <a href="https://developer.yummly.com">recipe API</a>. (This is free and simple, if you're a student.)
</p>
<p>
One thing I've learned from working with recipe data is that there's a lot of redundancy out there. The difference between the Hershey's and Toll House chocolate chip cookie recipes, for example, is literally only 1/2 a teaspoon of salt. In a world where anyone can change ingredients by 1/2 a teaspoon and call it a new recipe, someone's got to step up and summarize all this data. A visualization like Autocookie is a start.
</p>
<p>
Some other things I would like to add in the future:
<ul>
<li>Better unit conversion (e.g., things like "3 tsp" should be "1 Tbsp")</li>
<li>Add/remove ingredients (my current code is too janky to support this)</li>
<li>A way to scale outputs for different serving sizes</li>
</ul>
</p>
<p>
<h4>Related work</h4>
<ul>
<li><a href="https://www.ibmchefwatson.com">Chef Watson</a> (IBM): Suggests ingredient pairings but not quantities.</li>
<li><a href="http://www.cookingforengineers.com/article/309/Michael-Ohenes-Cookie-Recipe-Generator">Michael Ohene</a>'s cookie generators: <a href="http://www.whatsthesequency.com/cookieaab2.php">This</a> one is paywalled; <a href="http://www.easierbaking.com/">this</a> one is not.</li>
<li><a href="https://github.com/kkelk/MeanRecipes">This</a> project generates an average of all related recipes.</li>
</ul>
</p>
</span>
</div>
</div>
</div>
</div>
</div>
</div><!-- /.container -->
<link href='https://fonts.googleapis.com/css?family=Pacifico|Raleway' rel='stylesheet' type='text/css'>
<script src="static/js/jquery.min.js"></script>
<script src="static/bootstrap/js/bootstrap.min.js"></script>
<!--<link href="static/css/jquery-ui.css" rel="stylesheet">
<script src="static/js/jquery-ui.js"></script>
<script src="static/data/recipes.js"></script>
<script src="static/data/recipe-setup.js"></script>
<script src="static/js/fraction-0.3.js"></script>
<script src="static/js/ratios.js"></script>
<script src="static/js/about.js"></script>-->
<script type="text/javascript">
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-42857746-1']);
_gaq.push(['_trackPageview']);
(function() {
var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
ga.src = ('https:' == document.location.protocol ? 'https://' : 'http://') + 'stats.g.doubleclick.net/dc.js';
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
})();
</script>
</body>
</html>