Message Boards Message Boards

0
|
2239 Views
|
3 Replies
|
1 Total Likes
View groups...
Share
Share this post:

Rotating square's points

Posted 2 years ago

Hi, I'm trying to make a function to rate a square within a square, thus the second square will form a diamond.

I'm pretty new, so I think NestList is the way to go, however, I'm not sure how to rotate the coordinates of my polygon.

squarePts =  {{0, 0}, {1, 0}, {1, 1}, {0, 1}};

f7 = NestList[# ?? &, squarePts , 1]

I tried to get the middle points of each side and then rotate by 45 degree, but after the second square the thing become messy.

Thank you

POSTED BY: Isaac Keith
3 Replies
Posted 2 years ago

Crossposted here.

POSTED BY: Updating Name
Posted 2 years ago

For a more general solution, you might want to apply the transformation functions ScalingTransform and RotationTransform:

SquareTunnel[angle_, count_] :=
 With[
  {vertices0 = {{1, 1}, {-1, 1}, {-1, -1}, {1, -1}}},
  With[
   {center = Mean[vertices0], scale = (1/(Cos[angle] + Sin[angle]))},
   NestList[
    ScalingTransform[{scale, scale}]@*RotationTransform[angle, center], 
    vertices0, 
    count]]];

Graphics[{FaceForm[None], EdgeForm[Black], Polygon[SquareTunnel[Pi/8, 4]]}]

enter image description here

POSTED BY: Eric Rimbey
Posted 2 years ago

Not sure if I understand entirely, but the following might be what you want. I'll build up to it gradually.

You said,

I tried to get the middle points of each side and then rotate by 45 degree

If you can get the middle point, then you've already got the vertices for the next square. No need for a separate rotation. A simple way to get midpoints is with Mean:

Mean[{{a, b}, {c, d}}]

output: {(a + c)/2, (b + d)/2}.

Now what we'd like to do is to apply Mean to adjacent pairs in your squarePts. You could use Partition to make pairs and then map Mean over the result. Or you could use BlockMap. There are probably many other equivalent approaches, but I'll use BlockMap.

BlockMap[Mean, squarePts, 2, 1]

output: {{1/2, 0}, {1, 1/2}, {1/2, 1}}.

Oops. We need to "wrap around". BlockMap doesn't have an option to do that, but we can alter the data BlockMap is applied to.

BlockMap[Mean, PadRight[squarePts, 5, squarePts], 2, 1]

output: {{1/2, 0}, {1, 1/2}, {1/2, 1}, {0, 1/2}}.

Your NestList idea looks promising. It would be a bit clearer if we bundled what we've done into a function first.

InnerPolyPts[pts_] := BlockMap[Mean, PadRight[pts, 5, pts], 2, 1]

Now use NestList:

NestList[InnerPolyPts, squarePts, 3]

output: {{{0, 0}, {1, 0}, {1, 1}, {0, 1}}, {{1/2, 0}, {1, 1/2}, {1/2, 1}, {0, 1/2}}, {{3/4, 1/4}, {3/4, 3/4}, {1/4, 3/4}, {1/4, 1/4}}, {{3/4, 1/2}, {1/2, 3/4}, {1/4, 1/2}, {1/2, 1/4}}}.

Let's visualize our nested squares:

Graphics[{FaceForm[None], EdgeForm[Black], Polygon[NestList[InnerPolyPts, squarePts, 3]]}]

enter image description here

POSTED BY: Eric Rimbey
Reply to this discussion
Community posts can be styled and formatted using the Markdown syntax.
Reply Preview
Attachments
Remove
or Discard

Group Abstract Group Abstract