Skip to content

Commit

Permalink
Add house exercise (#293)
Browse files Browse the repository at this point in the history
  • Loading branch information
keiravillekode authored Jan 14, 2025
1 parent 761926f commit bb3af68
Show file tree
Hide file tree
Showing 10 changed files with 485 additions and 0 deletions.
8 changes: 8 additions & 0 deletions config.json
Original file line number Diff line number Diff line change
Expand Up @@ -489,6 +489,14 @@
"prerequisites": [],
"difficulty": 6
},
{
"slug": "house",
"name": "House",
"uuid": "914f654d-2d0c-4d4b-8c42-bff8ebdac21c",
"practices": [],
"prerequisites": [],
"difficulty": 6
},
{
"slug": "knapsack",
"name": "Knapsack",
Expand Down
6 changes: 6 additions & 0 deletions exercises/practice/house/.docs/hints.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# Hints

## General

- The `$t0-9` registers can be used to temporarily store values
- The instructions specify which registers are used as input and output
14 changes: 14 additions & 0 deletions exercises/practice/house/.docs/instructions.append.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
# Instructions append

## Output format

Output the lyrics as a null-terminated string.

## Registers

| Register | Usage | Type | Description |
| -------- | ------------ | ------- | ----------------------------- |
| `$a0` | input | integer | start verse |
| `$a1` | input | integer | end verse |
| `$a2` | input/output | address | null-terminated output string |
| `$t0-9` | temporary | any | for temporary storage |
105 changes: 105 additions & 0 deletions exercises/practice/house/.docs/instructions.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,105 @@
# Instructions

Recite the nursery rhyme 'This is the House that Jack Built'.

> [The] process of placing a phrase of clause within another phrase of clause is called embedding.
> It is through the processes of recursion and embedding that we are able to take a finite number of forms (words and phrases) and construct an infinite number of expressions.
> Furthermore, embedding also allows us to construct an infinitely long structure, in theory anyway.
- [papyr.com][papyr]

The nursery rhyme reads as follows:

```text
This is the house that Jack built.
This is the malt
that lay in the house that Jack built.
This is the rat
that ate the malt
that lay in the house that Jack built.
This is the cat
that killed the rat
that ate the malt
that lay in the house that Jack built.
This is the dog
that worried the cat
that killed the rat
that ate the malt
that lay in the house that Jack built.
This is the cow with the crumpled horn
that tossed the dog
that worried the cat
that killed the rat
that ate the malt
that lay in the house that Jack built.
This is the maiden all forlorn
that milked the cow with the crumpled horn
that tossed the dog
that worried the cat
that killed the rat
that ate the malt
that lay in the house that Jack built.
This is the man all tattered and torn
that kissed the maiden all forlorn
that milked the cow with the crumpled horn
that tossed the dog
that worried the cat
that killed the rat
that ate the malt
that lay in the house that Jack built.
This is the priest all shaven and shorn
that married the man all tattered and torn
that kissed the maiden all forlorn
that milked the cow with the crumpled horn
that tossed the dog
that worried the cat
that killed the rat
that ate the malt
that lay in the house that Jack built.
This is the rooster that crowed in the morn
that woke the priest all shaven and shorn
that married the man all tattered and torn
that kissed the maiden all forlorn
that milked the cow with the crumpled horn
that tossed the dog
that worried the cat
that killed the rat
that ate the malt
that lay in the house that Jack built.
This is the farmer sowing his corn
that kept the rooster that crowed in the morn
that woke the priest all shaven and shorn
that married the man all tattered and torn
that kissed the maiden all forlorn
that milked the cow with the crumpled horn
that tossed the dog
that worried the cat
that killed the rat
that ate the malt
that lay in the house that Jack built.
This is the horse and the hound and the horn
that belonged to the farmer sowing his corn
that kept the rooster that crowed in the morn
that woke the priest all shaven and shorn
that married the man all tattered and torn
that kissed the maiden all forlorn
that milked the cow with the crumpled horn
that tossed the dog
that worried the cat
that killed the rat
that ate the malt
that lay in the house that Jack built.
```

[papyr]: https://papyr.com/hypertextbooks/grammar/ph_noun.htm
19 changes: 19 additions & 0 deletions exercises/practice/house/.meta/config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
{
"authors": [
"keiravillekode"
],
"files": {
"solution": [
"impl.mips"
],
"test": [
"runner.mips"
],
"example": [
".meta/example.mips"
]
},
"blurb": "Output the nursery rhyme 'This is the House that Jack Built'.",
"source": "British nursery rhyme",
"source_url": "https://en.wikipedia.org/wiki/This_Is_The_House_That_Jack_Built"
}
62 changes: 62 additions & 0 deletions exercises/practice/house/.meta/example.mips
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
# | Register | Usage | Type | Description |
# | -------- | ------------ | ------- | ----------------------------- |
# | `$a0` | input | integer | start verse |
# | `$a1` | input | integer | end verse |
# | `$a2` | input/output | address | null-terminated output string |
# | `$t0` | temporary | byte | character being copied |
# | `$t3` | temporary | address | pointer into lyrics |
# | `$t5` | temporary | address | lyrics |
# | `$t6` | temporary | address | table |
# | `$t7` | temporary | word | "THIS" (4 ASCII bytes) |
# | `$t8` | temporary | word | " IS " (4 ASCII bytes) |

.eqv THIS 0x73696854 # "This"
.eqv IS 0x20736920 # " is "

.globl recite

.data

lyrics: .asciiz "This is the horse and the hound and the horn that belonged to the farmer sowing his corn that kept the rooster that crowed in the morn that woke the priest all shaven and shorn that married the man all tattered and torn that kissed the maiden all forlorn that milked the cow with the crumpled horn that tossed the dog that worried the cat that killed the rat that ate the malt that lay in the house that Jack built.\n"

table:
.word -1, 389, 368, 351, 331, 310, 267, 232, 190, 145, 99, 62, 8


.text

recite:
la $t5, lyrics
la $t6, table
li $t7, THIS
li $t8, IS

sll $a0, $a0, 2
sll $a1, $a1, 2
add $a0, $t6, $a0 # pointer into table for current verse
add $a1, $t6, $a1 # pointer into table for end verse

line:
usw $t7, 0($a2) # unaligned store word "This"
usw $t8, 4($a2) # unaligned store word " is "
add $a2, $a2, 8

lw $t3, 0($a0)
add $t3, $t5, $t3

copy_string:
# copy string from source $t3 to destination $a2
lb $t0, 0($t3) # load source byte
sb $t0, 0($a2) # write byte to destination
addi $t3, $t3, 1 # increment souce pointer
addi $a2, $a2, 1 # increment destination pointer
bne $t0, $zero, copy_string # repeat until we have reached null terminator

subi $a2, $a2, 1 # decrement destination pointer,
# ready to append other strings

move $t1, $a0
add $a0, $a0, 4
bne $t1, $a1, line

jr $ra
52 changes: 52 additions & 0 deletions exercises/practice/house/.meta/tests.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
# This is an auto-generated file.
#
# Regenerating this file via `configlet sync` will:
# - Recreate every `description` key/value pair
# - Recreate every `reimplements` key/value pair, where they exist in problem-specifications
# - Remove any `include = true` key/value pair (an omitted `include` key implies inclusion)
# - Preserve any other key/value pair
#
# As user-added comments (using the # character) will be removed when this file
# is regenerated, comments can be added via a `comment` key.

[28a540ff-f765-4348-9d57-ae33f25f41f2]
description = "verse one - the house that jack built"

[ebc825ac-6e2b-4a5e-9afd-95732191c8da]
description = "verse two - the malt that lay"

[1ed8bb0f-edb8-4bd1-b6d4-b64754fe4a60]
description = "verse three - the rat that ate"

[64b0954e-8b7d-4d14-aad0-d3f6ce297a30]
description = "verse four - the cat that killed"

[1e8d56bc-fe31-424d-9084-61e6111d2c82]
description = "verse five - the dog that worried"

[6312dc6f-ab0a-40c9-8a55-8d4e582beac4]
description = "verse six - the cow with the crumpled horn"

[68f76d18-6e19-4692-819c-5ff6a7f92feb]
description = "verse seven - the maiden all forlorn"

[73872564-2004-4071-b51d-2e4326096747]
description = "verse eight - the man all tattered and torn"

[0d53d743-66cb-4351-a173-82702f3338c9]
description = "verse nine - the priest all shaven and shorn"

[452f24dc-8fd7-4a82-be1a-3b4839cfeb41]
description = "verse 10 - the rooster that crowed in the morn"

[97176f20-2dd3-4646-ac72-cffced91ea26]
description = "verse 11 - the farmer sowing his corn"

[09824c29-6aad-4dcd-ac98-f61374a6a8b7]
description = "verse 12 - the horse and the hound and the horn"

[d2b980d3-7851-49e1-97ab-1524515ec200]
description = "multiple verses"

[0311d1d0-e085-4f23-8ae7-92406fb3e803]
description = "full rhyme"
11 changes: 11 additions & 0 deletions exercises/practice/house/impl.mips
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# | Register | Usage | Type | Description |
# | -------- | ------------ | ------- | ----------------------------- |
# | `$a0` | input | integer | start verse |
# | `$a1` | input | integer | end verse |
# | `$a2` | input/output | address | null-terminated output string |
# | `$t0-9` | temporary | any | for temporary storage |

.globl recite

recite:
jr $ra
Loading

0 comments on commit bb3af68

Please sign in to comment.