Subject:
|
Re: Rotating through a four-bit nibble
|
Newsgroups:
|
lugnet.robotics
|
Date:
|
Thu, 22 Sep 2005 18:45:09 GMT
|
Viewed:
|
1677 times
|
| |
data:image/s3,"s3://crabby-images/2f405/2f4052fc7f9b83394eac8c4fa1668e81096153a3" alt="Post a public reply to this message" | |
In lugnet.robotics, Brian Davis wrote:
> In lugnet.robotics, Kevin L. Clague wrote:
>
> > Since I didn't really complete the assignment I'll try again.
>
> Both your 1st & 2nd solutions are very good; thanks to you and other posters
> to this thread for giving me a much better handle on binary manipulations, and
> solutions to this problem. In answer to an earlier question, speed is important
> (simple (ie- no loop) maze solving for a line-follower), but so is size because
> this program is getting long fast. I'd like an entry for the ChiBots event which
> is a maze of 7x7 potential nodes, so bit representations for some things are
> going to save some variable space. As well as being a more "natural" way of
> doing it.
>
> > I confirmed that even SDK v2.5 does not have shifts
> > or rotates
>
> I guess I shouldn't have been too surprised by this - after all, it's aimmed
> at programming for kids, so such "low level" operations aren't going to be used
> very often (at all). Still, bit of a surprise - I was assuming I should use the
> shift operator for speed. Oh well.
>
> Now I need to figure out good ways to code all this (I've almost got the
> movement and detection routines polished, and the mechanical aspects were easy
> (because I'm reusing an older platform). Now I'm bumbing up against the memory &
> speed limitations of the standard firmware (but it's taken me something like
> four years to get there, so I'm not complaining).
Maybe it is time to move on to BrickOS?
int
rotate_right(
int value, // the value to be rotated
int width, // the width of the rotated field
int base, // bitnumber of rightmost bit in rotate field
int amount) // the amount to rotate between base and base+width)
{
int r,l;
r = value >> amount;
l = value << width - amount;
r &= (1 << (base + amount)) - (1 << base);
l &= (1 << (base + width)) - (1 << (base + amount));
value &= ~((1 << (base + width)) - (1 << base);
value |= r | l;
}
Kev
|
|
Message has 1 Reply: data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="" | | Re: Rotating through a four-bit nibble
|
| (...) BrickOS has mocked me from the horizon for some time, but there are two things that are holding me back: (a) Judging by the posts and what I've read, the learning curve seems awfully steep - especially since I'm on a Mac. (b) Rarely have I (...) (19 years ago, 22-Sep-05, to lugnet.robotics)
|
Message is in Reply To:
data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="" | | Re: Rotating through a four-bit nibble
|
| (...) Both your 1st & 2nd solutions are very good; thanks to you and other posters to this thread for giving me a much better handle on binary manipulations, and solutions to this problem. In answer to an earlier question, speed is important (simple (...) (19 years ago, 22-Sep-05, to lugnet.robotics)
|
13 Messages in This Thread: data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Rotating through a four-bit nibble -Brian Davis (20-Sep-05 to lugnet.robotics)" data:image/s3,"s3://crabby-images/c369d/c369d95f9d32e76ca197262d0f8bb1a7bd5bd83b" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -Timothy Gould (20-Sep-05 to lugnet.robotics)"
data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="" data:image/s3,"s3://crabby-images/327ab/327ab346086f4cc3ed2d80895f3f818baa8af239" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -lego-robotics@crynwr.com (T. Alexander Popiel) (20-Sep-05 to lugnet.robotics)"
data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="" data:image/s3,"s3://crabby-images/61fa4/61fa4e9aa3065ac3768e2bc54ec97731c8e6f235" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -Kevin L. Clague (21-Sep-05 to lugnet.robotics)" data:image/s3,"s3://crabby-images/c369d/c369d95f9d32e76ca197262d0f8bb1a7bd5bd83b" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -Kevin L. Clague (21-Sep-05 to lugnet.robotics)" data:image/s3,"s3://crabby-images/7f3b7/7f3b7bded1cc6a47e4241017a112fe11ff19bd8a" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -Brian Davis (22-Sep-05 to lugnet.robotics)" data:image/s3,"s3://crabby-images/7f3b7/7f3b7bded1cc6a47e4241017a112fe11ff19bd8a" alt="" data:image/s3,"s3://crabby-images/d2141/d2141c5df91cad3c69b2ba9383b7f58dd7d032bd" alt="You are here" data:image/s3,"s3://crabby-images/7f3b7/7f3b7bded1cc6a47e4241017a112fe11ff19bd8a" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -Brian Davis (22-Sep-05 to lugnet.robotics)"
data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="" data:image/s3,"s3://crabby-images/61fa4/61fa4e9aa3065ac3768e2bc54ec97731c8e6f235" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -Jordan Bradford (22-Sep-05 to lugnet.robotics)" data:image/s3,"s3://crabby-images/7f3b7/7f3b7bded1cc6a47e4241017a112fe11ff19bd8a" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -Geoffrey Hyde (22-Sep-05 to lugnet.robotics)" data:image/s3,"s3://crabby-images/7f3b7/7f3b7bded1cc6a47e4241017a112fe11ff19bd8a" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -Jordan Bradford (22-Sep-05 to lugnet.robotics)" data:image/s3,"s3://crabby-images/7f3b7/7f3b7bded1cc6a47e4241017a112fe11ff19bd8a" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -Kevin L. Clague (22-Sep-05 to lugnet.robotics)" data:image/s3,"s3://crabby-images/7f3b7/7f3b7bded1cc6a47e4241017a112fe11ff19bd8a" alt="" data:image/s3,"s3://crabby-images/51f21/51f217bb6cbbf92db8ab373fed6deaea207e93a9" alt="Re: Rotating through a four-bit nibble -Jordan Bradford (29-Sep-05 to lugnet.robotics)"
- Entire Thread on One Page:
- Nested:
All | Brief | Compact | Dots
Linear:
All | Brief | Compact
This Message and its Replies on One Page:
- Nested:
All | Brief | Compact | Dots
Linear:
All | Brief | Compact
|
|
|
|