professor: all right. so lecture 7 wasabout many things-- universal foldings by boxpleating, maze folding, and then lots ofnp hardness stuff. so we're going to go throughthings in that order. i thought i'd start by showingsome old history of box pleating, where it comes from. the first design is by this guyraymond mclain, 1967, design called the mooser's train.
and you can see all the creasesare horizontal, vertical, and diagonal, 45 degrees. this is the originalhandwritten thing, and this is apparently beforethe time of origami books, for the most part. so people wouldjust photocopy this, and hand it around, justkind distribute it out through the origami community. and kind of spawned arevolution origami design,
because it was thefirst model to make sort of a very complicatedmulti-object piece out of one piece of paper. happened to be arectangle of paper, but a pretty cool design . and it really gotpeople thinking about. and the basic, originalprincipal in box pleating was to make boxes, and then findways to attach them together. and it's fairlypowerful and believed
to be universal byorigamists for a long time. and we proved it withthat cube gadget. now, the designs that comeout of the cube gadget are not especially efficient. i've got some ways tooptimize it, as you saw, but at least it proveseverything is possible that you couldmake out of cubes, you can make outof box pleating. another kind ofinfluential design
is this blackforce cuckoo clock. for a long time, one of the mostcomplicated origamis out there. it was designed byrobert lang in the '80s, and there's a few ofthem in existence. it has lot of detail-- ithas a clock, that's correct twice a day, and it's hemodeled it after a real cuckoo clock he saw inthe black forest. it's got a zillioncreases, especially in this long rectangle of paper.
and there's diagrams for itin origami design secrets, if you want to make your own. and it's also based onthis box pleating idea, and sort of in the early daysof the tree theory, and so on. so really, before that kickedoff, box pleating was around. and people still dobasic box pleating, although now there'sthe fusion of the tree method with box pleating. there's a lot of designsbased on that, because they're
easy to fold fromangular perspective, easy to find where thecreases are, anyway, that's box pleating. so next, we go on to-- ithink it's an open problem. yeah, this is acool open problem. for some reason, neverthought about it. i'm sure briefly thought aboutit, but never worked on it. in the same way we getuniversal hinge patterns, box pleating can make any polycube, what if you want to make,
out of the simple cube gadget,can we design an analogous cube gadget fortetrahedra, octahedra, might be nice, regular octahedratile space, out of something like a triangular grid,maybe with 30 degree lines. that's a naturalquestion-- open. maybe we'll work on it sometime,but i think it'd be neat. you just need a nicegadget, and then we know how to compose them byinduction just like in lecture seven.
so it could be afun thing to attack. next, we go to maze folding. so i thought i'dshow-- we've seen this maze fold-- the 6.849. so this is foldedby jenny and eli based on the algorithm thatyou saw, and you might play with it on yourproblem set three. design your own maze. you can click anypattern you want.
make whatever letters you want,or any other cool orthogonal pattern. marty and i have made abunch of different print designs based around this ideaof taking not just the crease pattern you get forfolding-- here we're folding the word yesin three dimensions-- but we've shaded the originalpiece of paper in this pattern. so that it looks like nothingon here, but when you fold it, the shading comestogether to spell no.
so it's kind of ambiguity, orthe shadow of the yes is no, and so on. and jenny and eli foldedthat as well, and here it is. the first folding. but our idea is notnecessarily to fold them. i mean, it's cool thatthey can be folded. that's neatconceptually, but we also like to design ones thatreally should not be folded. next one here isscience and art,
so you fold the sciencein three dimensions and the art is in thebackground lurking there. i imagine this willnever be folded. it'd be rather painful. here's another verycomplicated one. here we're playing around withputting little shaded regions in these squares. these are just thesquares that end up mapping to the flatparts over here.
and so you get--we took an image and spliced it up intothousands of pieces. so you get-- this is aphotograph of martin gardner, who died a coupleyears ago sadly. we never met him,but he was the father of recreational mathematicsamong other things. also magician--lots of cool things. so this is in tribute to him. and this is our latestdesign in this spirit.
we're trying to be alittle more artistic and just be about the creasepattern, not necessarily the folding. so the 3-d thing that thisfolds into is not shown here, and in theory all theselines go off to infinity. but this spells the word glass. we made it when we were atthe pilchuck glass school this summer. and it's now on t-shirts of manyglass blowers around the world.
how many of them knowexactly what it folds into, i don't know. but that's pretty cool. so we were workingon glass folding, so that seemed like anatural thing to do. so that is maze foldingand see some designs. how you can use itfor cool things. the next topic isnp-hardness, and that will be what we spendmost of today on.
and so, first kindof general question is what does it all mean? what does np-hardnessreally tell you? can you give me like aspecific instance that's hard, and-- this is more for peoplewho haven't seen mp-hardness before-- the answer is no. np-hardness is kind of aconceptual, philosophical thing. no specific problemis ever np-hard.
it's all about whole familiesof problems being hard. and really it's aboutmeasuring the growth of problem complexity with problem size. so in this case, it'show much running time do you need tosolve your problem as a function ofthe problem size. and we're interested in whetherthat grows only polynomially or it grows exponentially,and np-hardness probably implies exponential growth.
a nice example of this is chess. so eight-by-eightchess-- people have spent many years trying tosolve it and do it perfectly, and to be the best player. but from a theoretical,computer science perspective, chess in its originalform, is trivial because it just has aconstant number of states. you could just enumeratethem all in constant time. you know who wins inchess-- probably white.
but it's not very satisfying,but the more interesting thing to say is to studychess as it grows, and the natural way to make itgrow is with an n-by-n board. so with an n-by-nboard, if i give you an arrangement ofchess pieces and i want to know who wins,that you can prove is something even stronger thannp-hardness called x-hardness. so there you can actuallyprove you need exponential time to solve n-by-n chess.
and that gives you a sensethe chess really is hard. there's not going to be a goodalgorithm that magically will solve it for eight-by-eight,because in general as board size increases, you know ithas to grow exponentially, and probably eight-by-eightis big enough. that there's no goodalgorithm to do it. you can't prove thatthere's no good algorithm to do eight-by-eight,but you can prove there's no goodalgorithms to do n-by-n.
so that's the limitation oftheoretical computer science and of np-hardness. so you take anyparticular crease pattern. you want to knowwhether it folds flat. you might be able to dothat by exhaustive search and exponentialtime might be ok, but you know that as thecrease patterns get big, you're totally screwed. so, next question abouthardness is can we
do it with a littleless hand waving? so in a little bitmore detail, because i covered a lot of proofs. so i'm going tolook at two of them. the simple full hardness--which is from partition-- and the crease patternflat foldability which is from not all equalsat-- 3sat-- and i'll give some more details. so let's start by goingthrough this proof.
remember, in general withan np-hardness reduction, we want to take someknown hard problem and convert it into ourproblem, because that proves that our problem is at leastas hard as the original one. so in this case, the knownhard problem is i give you n integers-- a1, a2, up to an. and i want to know, can isplit them into two groups so that the twogroups have equal sum? and here we're mapping that intothe simple fold problem, which
was given a creasepattern can you fold it. can you follow all thecreases flat by simple folds? we're mapping itinto these lengths-- these lengths are the aisbetween the different legs of the staircase. and then there'sthis extra stuff. this is a super longlength-- length l-- and this is a doublysuper long length-- 2l. and then there's thisframe, which has height 2l,
and this part is alignedright at the midway. and so the idea was if there'sa partition-- if there's a partition of the aisinto two groups-- call them group a and groupb-- then i'm going to fold some of the creases. the ones between any twoguys of different groups. because folding here correspondsto switching directions. so whenever i fold, i'm kind ofswitching which group i'm in, and then group a willbe all the up directions
and group b will be allthe down directions. so maybe both of theseguys are in group b so they both go down, and thisis a group a guy, so we go up, and then down, and then up. and if we get them-- a andb to be balanced-- then we'll end up rightwhere we started. so we'll end up right atthe middle point here. and, in that case, there'sthese two more folds-- this vertical fold andthat vertical fold.
and then if you-- sorry. yeah, i don't haveit drawn here. when you do one more fold here,this will fall into the frame, and if you got this to stay--if you got this point basically to be aligned withhere, then going up l, and then back down to l willnot collide with this box. it just barely fits,and so you fold that in. then you fold this verticalline and you fold it back out. so the goal was just toget these two folds made.
once they're made andit's back out here, you can finish all foldsthat you didn't fold before. and what we're checking hereis that during all this motion, you don't get collisionbecause simple folds are not allowed to collideduring the motion. so if this, for example, wenttoo far down or too far up and it collided withthe frame, then you wouldn't be able to make thesecond vertical fold here because you'd have tobring the frame with you,
and the frame's notsupposed to move. so in particular,there's this question. seems like we're notmaking all the folds, and that's because ididn't say the last part. after you fold it inhere and avoid collision, you fold it back out with thesecond of these two folds. then you can finishall the folds. indeed the goal isto fold everything, but in order to avoidcollision, when i fold this,
this thing has to be nice andcompact and fit within this 2l boundary. then it goes through. so what we reallyneed to show though at the top level isgiven any set of ais, we can convert it into anequivalent simple fold problem. there's actually two things weneed to check for equivalence. we need to check thatif there's a partition, then there's a way to fold it.
we also need to checkthe reverse, which is if there's a way to foldit, then there's a partition. but both of these kind offollow from this argument. in order to-- whenwe make this fold, this guy's got to-- orwhichever of these two is first. they're kind of equivalent. if we collide, we won't beable to finish the folding. that's the claim. you might have done allthe folds over here,
but they'll be thesecond of these two, and so when you do the first,you'll either get stuck or you'll be able to proceed. if you were able toproceed, you can read off from the ups and downs herewhat the partition was. so you can convert in eitherdirection using this reduction. any more questions aboutthe simple folds one? so, of course, one of the easierproofs, the crease pattern flatfold ability is definitelyon the more complicated side,
and this was theoverview of the proof. basically there were lotsof little local gadgets. there's the wire,which communicates truthiness or falsityas we like to say. or things like-- themain gadget is the one at the top and notall equal clause, which forces among thethree wires coming in. they can't all havethe same value. so there could betwo true, one false.
or two false, one true. but not all trueand not all false. and then we neededsome auxiliary gadgets for turning, duplicating,and crossing over. those were fairlystraightforward. the heart is a wire, anda not all equal clause. and so the idea was we weregiven a formula-- in this case, it's a bunch of triples,and each of the triples should be not all equal.
and there's like nvariables-- there's a lot of different clauseson those variables. a lot of not all equalconstraints on those clauses. we want to represent thatby the flatfold ability of the crease pattern. so we basically makeall the variables off the left edgeof the paper here. we make lots of copiesof them by zigzagging, and then we make lots of clausesat the top-- only drawn two
up there-- and then in our inputwe're given a bunch of triples of variables that shouldbelong to a common clause, and we just route thesesignals to go to that clause. and then the clauses constrainthe values of those variables to be not all equal inthe appropriate triples. and the splittersdown here enforce all the different copies ofthat variable to be the same. and so any flatfolding will require these guys are consistentlyassigned one truth
value throughoutthe construction, and those clauses willforce not all equal things to be seen in pairs. so if there's a flatfolding of this, you can read off on themountain valley assignment here which one basedon whether it's left valley, right mountain,or left mountain, right valley. you can read of whatthe truth assignment is that satisfies all the clauses.
that was one directionfrom flat foldability to satisfiability of thenot all equal triples in the reverse direction. if there's a not all equalassignment of triples, you need to verify that thisthing actually does fold flat. i didn't detailthat, but basically to do that, you have to provethat each of the gadgets works exactly as desired. so you could really fold itflat if these have equal value,
for example, and thishas a negated value. you could actually alwaysfold the not all equal cause when it's satisfied. and then once you know thateach of these gadgets-- because the gadgets arevery small-- once you know that each of themfolds correctly, and they have a sortof comparable interface because these things arejust extending through, you could basically pasteglue together all of those
folded states. so as long as youverify the gadgets work, the whole thingwill work provided there is a satisfyingassignment. so that's-- yeah, question? audience: can you actuallygo in the other direction properly in the same cell? can you map any flatfoldability [inaudible]? professor: ok, can youmap any flat foldability
of a crease patternproblem to sat? that doesn't followfrom this proof, but i think it should be true. uh, let's see-- i think so. so if i give youa crease pattern, i want to knowwhether it folds flat. as mentioned in lecture,you can determine where all the facets lie in 2d. and challenges thestacking order,
which implies the mountainvalley assignment. so i think you couldmake a variable in a sat problem for this piece--this little polygon lives in the stacking level. you have to figure out how manylevels you need, but at most 10 of them, i guess. and then write downthe constraints between different polygonsif there are no crossings. there's a paperby jacques justin
that does that explicitly. so that should give you a way toreduce to sat, which gives you an algorithm-- an exponentialtime algorithm to solve it. in general, i'm prettysure this problem is in np, which implies there'sat least an algorithm for it. but i think in particular,you can reduce it to sat. so that's a good question. so pretty muchevery problem we'll talk about at least withorigami has a finite algorithm
to solve it, but it's a veryslow algorithm in general. of course, there's a lot ofgood sat solvers out there, and i don't know if peoplehave actually tried to do that. i know there are some-- there'sa software called oripa, which in japan someversions try to find a valid folding-- avalid folded state by some kind of careful,exhaustive search. i don't think they usesat solvers though. you might get more mileageout of sat solvers.
other questionsabout this proof? there's one explicit questionabout the reflector gadget. this probably worth talkingabout because these arrows are maybe not soobvious what they mean. so the question is whatis true and what is false. it's kind of philosophy,but in this case these arrows are explicitlydrawn on this diagram. if you look closely, there's anarrow this way, then this way, then this way.
and that's defining what we meanby the orientation of a wire, and then if it's a valleyon the left relative to the arrow, that's true. if it's mountain on theleft relative to the arrow, that's false. and that's why thisis drawn this way assuming i got it right. here it's valley on theleft relative to the arrow. here it's mountain on theleft relative to the arrow.
so notice these are pointingin different directions. so that can get alittle confusing, but it's kind of whatwe want in that proof because we really want to routethat thing in this direction. we don't care aboutwhat things look like relative tothe center here. because the center-- thegadget we are looking at keeps changing. so we want to routethis as a single wire.
and this one ialready talked about. you need to proveboth directions-- that flat foldability impliesnot all equal satisfiability, and the reverse. ok, we move on. so now we get tosome new material. so i mentioned in thelecture that there are two hardness proofs. the one we've been talkingabout is given a crease pattern,
does it fold flat? that's strongly np-hard. and the other is if igive you something-- i might even tell youit's flat foldable. that's kind of not too relevant. but i give youmountains and valleys, and i want to know--i want to find a valid foldedstate of that, or i want to decide whetherthe mountain valley
pattern is valid. these are strongly np-hard hard,and this is a different proof. it uses completelydifferent gadgets. so i thought i'd show yousome of those gadgets. sort of the key ones. so the first partis the wire, and i think i made one of these. maybe i didn't. no wire.
well, this is the endof a wire-- er, no, that's not the end of a wire. here's an end of a wire. so the idea here is we'vegot a fixed mountain valley pattern now because that'sno longer free for the folder to choose. and you've gottwo tabs, and they could stack oneway or the other. in this case, theycan stacked like this,
or they can stack like that. so i've got achoice in stacking. that changes the folded state. that's the choice that thefolder is going to make, but in either case the mountainvalley assignment is the same. so that's how we're going tocommunicate true and false, and i haven'tprovided orientation. should have drawnan arrow there. next gadget is this tabgadget, and this is just
a tool for buildingweird shapes, and it's kind of similarto some of the things you've seen in thecheckerboard folding. so our crease pattern lookslike this, and fold it flat. and there's two ways to fold it. actually, a fewdifferent folded states. but in particular,there's a state like this where there's thisindividually manipulatable tab, but there's no crease here.
so it can't go backwards. the crease is in here. so it's got a falldown like that. ok, so what this reductiondoes is, ahead of time basically, force alot of these foldings. and so we startwith a square paper. we end up with a smaller squarepaper with tabs sticking out in various directionsof various places. so this is much messierand it'd be harder
to draw the whole diagram ofwhat your crease pattern looks like, but in theoryyou can do this. that's also kind oflike the box pleading method where you justmake a cube ahead of time, and it's like you hada square originally. there just happens tobe a cube sitting here, and then you do other folding. and the angles in thiscrease pattern-- these are not 45 degrees.
they're at a bitof a weird angle to basically forcethis to happen first. it can't interact withany of the other gadgets that i show you. because you've got to get rid ofthose angles in the beginning. then, the main gadget hereis the not all equal clause, and that's what ihave folded here. so it's a little crazy,but basically you've got three pleats-- three ofthese double pleats coming
together. these guys could stack-- thisone on top, this one on top. now we're the samefor all three of them, and then you've got this littletwist like thing in the center, and it's reallyhard to draw what the folded state looks like. this is what it lookslike within shadow pattern with transparency. here's the real thing.
and also, there'sthese yellow tabs attached at veryspecific locations. and this is a littlehard to imagine. i encourage you to foldone of these in order to really see what's going on. but as i said before, you'vegot-- each of these guys can be independently stackedone way or the other. there's that one or this onecan stack this way or that way for all three, but we wantto forbid the case where
they're all stackedthe same way. and the arrows here are allpointing towards the gadget. so we want to forbidthe case when they're all-- when it'srotationally symmetric. gadget is rotationallysymmetric, but if you choose the layerorder rotationally symmetric, you're in trouble. so let me make itrotationally symmetric. that would be like this.
so when it'srotationally symmetric, you see-- basicallyall the panels you see-- there's three panels. this one, thisone, and this one. each of them has atab sticking out, and basically these tabs haveto also be cyclically ordered, but it's not possible--this is hard to do. it's like this. you see they're kindof colliding here.
because if you look at eachof the tabs in projection, it collides with wherethe tab is attached. so you basically-- if you went--so someone has to be the lowest tab, and that tab will intersectthe other two tabs actually where that tab is attached. so it'll penetrateand you can see they're not veryhappy to stack here. but if i change thelayer order in any way, our lowest tab is actuallyhappy to go behind other layers,
and then you can just stackthem, and they barely fit. so it's a little tricky to getall the details here to work, but i think this particulargeometry-- and the reason i drew this in this exact wayis to make sure yeah, everything works. you do not penetrate here,which would be a problem. you do not penetratethis crease, which would be a problem. so the tab just fits inbetween here and here,
but it does cross. if you look at this tab,it's attached along this edge as drawn up there. and this tab here will penetratethis part of that edge, and it will penetrate thispart of this edge which is where this tab is attached. so they cause trouble inthis cyclic situation, but when it's a cycliclike in this picture, you can put thatbottom tab way down
here and avoid any collision. then you can basicallybreak the cyclic condition, and you get to stack themin some linear order. so it's a little hard tosee without physically manipulating it. feel free to come andplay with that after. that's their proof. now there's also splitters, andturn gadgets, and crossovers, but i'll leave it at that.
those are more similar. this is the heart of what'sgoing on in this proof. so it's a completelyseparate proof from the one that we saw before. any questions about that? all right-- audience: here. professor: yeah? audience: i don't understandwhy the tabs fold.
professor: how do the tabs fold? audience: no, why do we needtabs if everything folds? professor: so the tabsare being used as a device to build gadgets. so the tabs serve nopurpose by themselves. but this gadget involvesfirst folding three tabs here, which are actuallypointing-- they're pointing in thatdirection, i believe. then you add this creasepattern afterwards.
so originally thereare tabs here, which means there's abunch of creases here. after you fold them, then youlay on this crease pattern. so if you unfolded it, youget some much more complicated crease pattern. which is when i made that,i just taped the tabs on. but in reality, first you foldthe tabs so they exist there, then you fold this on top. so the fold crease patternwould be quite complicated.
it's going to havetabs here, tabs here, tabs there, and then thisreflected a few times. and so then when youfold it-- the fold gadget is this thing with the tabs. the tabs are justlike a stepping stone toward making this gadget. the other gadgets use more tabs. obvious open problem here isto make a simpler reduction. shouldn't have tobe this complicated,
and i've heard tom hall talkabout different approaches for making simplernp-hardness proofs, but we're not there yet. other questions? audience: so these proofsdon't imply anything about the [inaudible]? they can all be veryeasily [inaudible]. professor: so this proofimplies these kinds of tessellation style creasepatterns are hard to fold,
which implies thatin general crease patterns are hard to fold. but you could look at someother specific pattern. for example, it'sthe next topic. you could look atmap folding where you have horizontaland vertical creases in a rectangular sheet of paper. maybe each of these squaresis-- or each of these cells is a unit square, let's say.
and i give you a mountainvalley assignment on that. some of these are mountains. some of them are valleys. whatever. and i want to knowdoes this fold flat? that we don't knowthe complexity of. could be solvable bypolynomial time algorithm. could be np-hard. and this is actually mentionedin lecture two notes,
but not actually orally. and so i wanted toget back to this. this is from lecture two notes. 2d map folding, jackedmonds poses this problem, can you characterize flatfoldable mountain valley is there an algorithmor is it np-hard? and even the 2-by-nproblem was open when i wrote thesenotes in 2010, but it has since been solved.
so i thought i'd tell you alittle bit about that solution. so yeah, there can be specialcases of crease patterns that are easy to solve. we just know ingeneral they are hard. so 2-by-n is thiskind of picture. so this is what i call2, counting cells. this is based on a classproject in this class from two years ago byeric lew and tom morgan, but the paper gotfinished this year.
so it's based on aseries of reductions. on the one hand, we're going tostart with something called-- ok, so we have mapholding on the left. we're going toconvert map folding into a different presentation,which is news labeling. we're going to convert thatinto something called a top edge view. we're going to convertthat into a ray diagram. and the last part, which iwon't talk too much about,
is we convert that intosomething called a hidden tree problem. each of these steps isfairly straightforward, but there are obviouslya lot of them. but in the end, you get apolynomial time algorithm to solve this, which impliesyou get a polynomial time algorithm to solve this. and i'll talk mostlyabout these reductions. it's the same ideain np-hardness.
we use reductions from ahard problem to our problem. in this case, we'redoing the reverse. we're reducing our problemto an easier problem, so that by the end weget something that's so easy we know how to solve it. the reductions are usefulboth for positive results and negative results. so let me show youvisually some-- oh, before we getto the proof, i
wanted to mention thispuzzle which you probably folded in problem set one. it's a map folding problem. it's a 3-by-3 map,and so we didn't have any good algorithmsto solve them. so we used a notso good algorithm-- namely exhaustive enumeration. we enumerated all possiblefolded states of a 3-by-3 map. we drew them out graphically.
there's a scroll bar here,so you don't see them all. but we put them ina giant-- i forget, there's 1,000folded states or so, so it's like 100-by--whatever-- 10 array. and for each ofthem-- so here's where you're designing your pattern. so you could make holes. you could put in patterns. this is sort of an early designwhere it would spell mit.
the hole would showthe i on another side, so it's equivalent tothe puzzle you solve. and this is whatthe top looks like. this is what thebottom looks like. so you can hover over theseand change the letters that appeared, and thenit would show you what every singlestate would look like, and it would color it in yellowif one side looked like mit, and it would color it in redif both sides look like mit.
and the point wasto verify there was exactly one solutionfor that puzzle. and so we kept-- wewould fold things to make it a tricky fold. then we put into thesoftware and label things accordingly, thenput into the software and see is there unique folding? and then we could add inextra misleading clues here, and see did they accidentallymake an extra solution?
so we could add inextra stuff to pack in. as much irrelevant stuff as wecould, and still make it unique so it's more challenging. that's a nice use of exponentialalgorithms to design puzzles. all right, butback to this proof. so i have here a muchsimpler map than this one. this is what wecall the new map. n-e-w. so the labelinghere is very simple.
if you look at this creasepattern, by [inaudible], there's got to be three of onetype and one of the other type. so just label each vertexby which way is unique. so from here, thenorth direction is the uniquely label-- it's themountain among three valleys. and then this vertex--the east label-- is the mountainamong three valleys, and then the next one is thewest label among three valleys. of course it doesn'thave to be like that.
it could, forexample, you can have three mountains at a vertex,but then the label of this guy's going to be w. it's goingto be the one that's unique among the other three. so if you fold thismap, it looks like this. i have one here, but it'sa little hard to see. we've got lots of backand forth on the top edge. some orienting it so thatthe-- we've got 2 by n maps. so there's twocritical features.
there's the center line. i'll call that thespine of the map. there's the top sideand the bottom side. when you foldthat-- this is just a sequence of simple folds. you see at this last fold, thetop side and the bottom side come together, and thespine is-- stays together. so when i orient it likethis as in the picture, the top side is where originallythe top and the bottom
of the map all come to herebecause of that spine fold, and the spine foldsare all down here. you can't see themhere, but there's you can see them atthe bottom there. there's some kind ofconnections on the bottom, but there's this nice relativelyone-dimensional picture up here. so we're going to draw that. this is the top edge view.
got clipped a littlebit, but there's one more segment at the top. so that is just this. see it? now there's alsothese blue lines. the blue lines correspond towhat's going on at the bottom from the spine. because if you thinkabout it, you've got the-- in a2-by-n map-- you've
got the top panels and theseedges making the top edge. and you've also got thebottom panels and these edges making the bottom edge. they come in pairs. these guys are paired up. these guys are paired up,and so on down the line because they arejoined by a spine edge. those spine edgescorrespond to the things on the bottom of thefolding, and they
need to not cross each other. and that's what's illustratedby the blue connections. so the very top edge is pairedwith the very bottom edge. these two-- this panelhere and the back panel here-- are connectedon the bottom. and that-- i'm sorry,that's not true. this one is pairedwith this one. the top one is pairedwith the second one. so it's actually these twoare connected on the bottom.
that's this little connectionhere, and then these guys-- this wraps around everything. that's that connection. but what you can't seeit in this folding-- because it's hidden inside--is that within this connection on the bottom, there's thisconnection on the bottom. and within that one,there's this connection. now this is ok. might look like they're crossingbecause they're overlapping.
but as long as theyare nested-- as long as you don't start frominside here and go to outside. that would be a crossing. you start inside,you should end inside like in all these pictures. if you start outside,you should end outside. so that's why-- these guysare disjoint, so that's ok. this is nested inthat, so it's ok. kind of likebalance parentheses.
and so that's what it makes. a top valid top edge view. what's nice about this is it'sa one-dimensional diagram. what's not nice is it has allthese crossings because there's the blue stuff on topof the black stuff. so it's a littlehard to find-- we're trying to find avalid folding state. we're trying tofind one of these. we're not restricting ourselvesto simple folds here yet.
simple map folding we alreadysolved in lecture two. so this is all-- i should'vesaid non-simple folds. that's what makesit hard, and that's what's still openfor 3-by-n maps if you don't know how to do it. but for 2-by-n maps,we've made two steps here. we have another view,which is the ray diagram, and this is reallyspecific to 2-by-n. and it lets us reduceto a tree problem.
so before we get there,let's talk in general about the top edge view. you can actually convert fromthe north, east, west, south labeling to a top edgeview in the following way. whenever-- and you can kindof see what's going on. so first we have an n. so we've got thesetwo guys, which are just pairedtogether happily. that's the beginning of the map.
then we turn left, and we've gotthis guy paired with this guy. and so, in general,whenever you have a north, you turn left withyour two guys. so that's what happens. then we hit an east inthe map, and what happens here is this guy turns right,but this one turns left. this is what you mightcall an inside turn. it's like an insidereverse fold in origami. and in general, wheneveryou have an east,
you turn inside like that. so this guy's pairedwith that one, and now this guy'spaired with that one. they both turn in. and then it's symmetric. next one is a w, which isthe opposite of an e, which means you turn out here. and in general, whenever youhave a west, you turn out. and a south, you turn right.
so those are thefour possible things you could imagine when youhave a pair of things turning, and those exactly correspondto n, e, w, and s. so it's clear what you needto do in this situation, but there's flexibility, right? for example, this guy--when you turn out-- here i turned out to thevery next layer, but this could haveturned out to go up here. would that be ok?
ah, no. if this one turnedout to go up here, that edge up there would bepaired with this one down here. so there'd be a blueline going like that, and that would be acrossing situation because that blue linewould cross this one. because it starts insideand it goes to outside. so it's a little tricky. this definitely gives yousome of the layer constraints,
but it doesn'tcheck for crossings. which is the bigchallenge in this problem. so we're going tosimplify this diagram. so just think abouttop edge views. forget about map folding now. you can forget aboutthe previous layers, and we are now focusingon this reduction. so we've got top edge viewconverting to ray diagrams. you can see it's much simpler.
this is the ray diagramof that picture. and essentially--there's two ways to think about what we're doing. instead of having two edges,and we track two edges turning, we just want one edge. that's one thing we're doing. you can think of that astracking the spine instead of the top and the bottom sides. but it's a little-- ray diagramsare going to get confusing.
i'll just tell youthat right now. every time i lookat it, i understand it a little bitmore, but it's not going to be obviously thatthis is equivalent to this. i'll just tell you--here's an alternate way to think about it. basically, the vertical--the y direction here is going tobe nesting depth. so whenever we go inlike this, we go deeper.
so for whatever reason,i flipped the labeling, but it is indeed east. when you go in, you go down. i should have just moved thesetwo figures so they correspond, but when you go east you godown a layer because you're nesting deeper. and when you go west,you're going out, so you go up a layer in thisnew weird ray diagram view. and north and south turn outto not turnaround in this view.
we're just going tofire a ray downward, and there's either anorth ray-- a blue one-- or a south ray-- a red one. and so if you followthis diagram, it's n-e-w. so first we have an n, whichmeans we shoot a ray down. then we have an e, whichmeans we turn downwards. and then we have a w, whichmeans we turn to go up a layer. and i haven't told you whatthe constraints are here, but i claim this is a validfolding just like that one.
and it's obviously alot easier to draw. it's a much slower complexity. but the cool thingis you no longer have these crossing parts. so let me show you--first, let me tell you what the constraints are. so in general, you're goingto have lots of downward rays. this is a north. this is a south.
a north, a south. so if you had like n, s,n, s, in your pattern, it's just going tobe a straight segment with downward raysof different colors. first constraint is whenever youhave a an n ray-- a north ray-- it has to hit another northray or just go off to infinity. and the same-- south rayscan only hit south rays or go off to infinity. so they line up inthis way, but you
can stretch the x-coordinateto do whatever you want. this corresponds to basicallyjumping over a bunch of layers. when you turn inyour folded state, you can skip a bunch oflayers and just go up here. so that corresponds to jumpingover a bunch of folds here. but in particularwe get these things called constrained segments. constrained segmentsare portions of this black spine betweentwo rays that below it only
see black. ok, so for example, thisone is unconstrained, because below it, youcan see off to infinity. so that's unconstrained. we don't care about that one. but among unconstrainedsegments-- these are twoconstrained segments-- we want that all of the raysthat they see below them-- so here i see one redray, one blue ray-- i want
the number of redsand blues to be equal. so this is valid becausethere's one red, one blue. this one is invalid becausethere's two blue and one red. this turns out to bethe right constraint. essentially this is sayinghowever much you spiral, you should spiral. that's the intuition. so here you're spiralingtwice, unspiraling once. so you're trapped inside, andso these folds cannot actually
come together. the rays comingtogether correspond to a nice nestingbetween two north folds. so it's not obvious,but this turns out to be the onlyconstraints you have. the black shouldnot cross itself. constraint segments shouldbe valid in this way, and blue should hit blueand red should hit red. so that's not obvious,but it's true,
and then you can take verycomplicated diagrams like this and simplify them intothese nice pictures. so these are twodifferent foldings of the same pattern,which i guess is n-e-n-- i can seethat easily here. you could have alsoextracted it from here. there's two foldingsbecause these two layers could go here in the middle. or they could be pushedup to fit in here,
and then we get this picture. and in the ray diagram--you can see this pretty easily-- either you havethese n rays just both go off to infinity, and this is anunconstrained segment so we don't care about that there'sonly one north ray below. or, you can extendthe x, because i can stretch thex parts however i want and make these bluesegments align with each other. and that correspondsto this folding.
so really, all foldedstates of the original thing are represented bythe ray diagram. of course, if i had anyw, this would be valid, but this would not be that. n-e-s-- blast from the past. if i had n-e-s, then this wouldbe blue, this would be red, and so this would be valid. but this would beinvalid, and so on. so it's obviously a loteasier conceptually,
but you can also-- and here'sa more complicated algorithm. you take a really crazy map. this notation, by theway, was introduced by jacques justinlike late 1980s. you may remember his namefrom kawasaki-justin theorem. so at the same time hewas looking at map folding and he came upwith this notation, the ray diagram was introducedin the open problem session in this class two years ago--or actually five years ago
if i recall correctly-- bydavid charlton and yoyo zhou. and then it was pickedup again two years ago, and finally we tookthis ray diagram and came up with an algorithm. so how does the algorithm work? here's a raydiagram-- the black, and the red, and the blue. we observe that the blankspace here between the spine stuff-- between all the black--is kind of a tree structure.
you've got-- andthat's what's drawn in cyan with the red dots. so if you draw a node every timeyou turn around on the outside. then you say, well, i can getfrom this node to this one, so i'm going to drawa segment there. and i can get fromthis node to this one without crossing any black,so i'll draw a segment there. that's sort of it on that side. there's nothing else down here.
that sort of doesn't count. but here's there'sanother dot, and i can get from this oneto there by going out here without crossing black. here to here, here to overhere without crossing black, so that cyan structure isa tree-- has no cycles. which in general is goodnews for algorithms. trees are relativelyeasy to find algorithms for using dynamic programming.
if you've seen dynamicprogramming for trees, this is not like that. it's a little different becausewe don't know what the tree is. we have to figureout what the tree is. but basically, we canguess the tree recursively. so there's some firstnode-- i don't know, maybe it's this one--just guess that. not randomly, but guessmeans try all the options. so you guess some node, andthen ok, we've got-- maybe
we've got two subtrees. maybe we've got three. i think that's aboutall there could be. and so, just guessed that,and then so recursively guess a subtree here anda subtree here. and each of the subtrees corresponds to a sub segment of this--of the original map. the spine, roughly speaking. and roughly speaking,these portions
do not interact with each other. there's this issue ofhow the rays align, and that's sort of the challengein getting this algorithm to work. but you can essentiallylocally check whether a subtreeis good enough. that it will interact okwith a different subtree, and just split thisproblem up recursively guessing all the way.
effectively trying alltrees, but in polynomial time instead of exponential time. forget the running time issomething like n to the 10 or some really big constant,but at least finally we know 2-by-n maps can besolved in polynomial time. we give the mountainvalley assignment. we still don'tknow about 3-by-n. that's the open question, andthese techniques unfortunately don't seem to apply.
you definitely don'tget a tree anymore. you might get somenice structure that's kind of vaguely treelike, but this was already super complicated. so we've gotten stuck here. any questions? all right. that's it.
Post a Comment for "crossover suv ford edge"