Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add syllabus docs #369

Merged
merged 44 commits into from
Sep 19, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
66f0996
Add syllabus docs
ErikSchierboom Jul 6, 2022
c3f3e3a
Draft introduction to syllabus design document
kytrinyx Aug 15, 2022
153846f
Tweak syllabus docs
kytrinyx Aug 15, 2022
1929f87
Add stub documents for syllabus-specific 'getting started' documents
ErikSchierboom Aug 16, 2022
b592ee8
Add some notes about first exercise in syllabus
ErikSchierboom Aug 16, 2022
52f8678
Add some notes about next exercises in syllabus
ErikSchierboom Aug 16, 2022
7b93abc
Add some notes about expanding exercises in syllabus
ErikSchierboom Aug 16, 2022
c529f30
Expand on building out the syllabus
kytrinyx Aug 17, 2022
d25afba
Flesh out syllabus docs
kytrinyx Aug 17, 2022
3931c94
Tweak syllabus docs
kytrinyx Aug 17, 2022
d7ce02b
Add note about creating issues to syllabus docs
kytrinyx Aug 18, 2022
e3fbb33
Update syllabus docs
kytrinyx Aug 30, 2022
258b4a1
Tweak wording on syllabus docs
kytrinyx Aug 30, 2022
7bce1ea
Tweak wording on syllabus docs
kytrinyx Aug 30, 2022
fa06929
Update syllabus docs
kytrinyx Aug 30, 2022
d66d32f
Add specifics about where and how to ask for help to syllabus docs
kytrinyx Sep 7, 2022
b908c38
Add a bit more about cyclic dependencies
kytrinyx Sep 7, 2022
6010970
Add a note about non-idiomatic code in syllabus docs
kytrinyx Sep 7, 2022
0cf5db7
Add spaces around emdash for readability
kytrinyx Sep 7, 2022
9e25304
Adjust initial goal explanation of first concept exercise
kytrinyx Sep 7, 2022
9856904
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
8736500
Add. missing spacing in syllabus docs
kytrinyx Sep 19, 2022
34a2ee0
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
7cfd5cd
Appease markdown linter in syllabus docs
kytrinyx Sep 19, 2022
c204316
Use more common form of gerund in syllabus docs
kytrinyx Sep 19, 2022
0a729f2
Use more common form of gerund in syllabus docs
kytrinyx Sep 19, 2022
2ab1502
Appease markdown linter in syllabus docs
kytrinyx Sep 19, 2022
c9825e8
Fix typo in syllabus docs
kytrinyx Sep 19, 2022
043046a
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
97b89f5
Change team name in syllabus docs
kytrinyx Sep 19, 2022
99c7565
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
b7f119a
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
4176c45
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
ef643ec
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
6930e41
Improve formatting in syllabus docs
kytrinyx Sep 19, 2022
3622c8c
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
c48692a
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
1e2ac24
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
9f62c7c
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
434f48d
Clarify syllabus docs
kytrinyx Sep 19, 2022
d646107
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
4708642
Improve wording in syllabus docs
kytrinyx Sep 19, 2022
a228bf1
Remove unnecessary 'here' when linking from syllabus docs
kytrinyx Sep 19, 2022
d29d0d7
Add suggestion to syllabus docs
kytrinyx Sep 19, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Update syllabus docs
  • Loading branch information
kytrinyx committed Aug 30, 2022
commit e3fbb33605b5296260c73a8072ad7495b759031e
45 changes: 42 additions & 3 deletions building/tracks/syllabus/README.md
Original file line number Diff line number Diff line change
@@ -1,25 +1,41 @@
# Syllabus
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

A track's [Concept Exercises](/docs/building/tracks/concept-exercises) are exercises designed to teach specific (programming) concepts.
A fully featured Exercism track has two types of exercises: Practice Exercises and Concept Exercises.
Concept Exercises and Practice Exercises are fundamentally different and complement each other well.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

A track's [Concept Exercises](/docs/building/tracks/concept-exercises) are exercises designed to teach specific concepts that form the basis of a programming language.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved
These concepts form a _syllabus_.

This documentation contains pointers and tips on how to succesfully design a syllabus for your track.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

## The goal of a syllabus

The end goal of a syllabus is to lead students to be comfortable with idiomatic code in the target language.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

Each individual Concept Exercise is very tightly focused.
It is a very small step that moves the student towards understanding something about the language.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved
It builds only on concepts that have been introduced previously.

By solving the exercise, the student begins the process of becoming familiar with the concept.
Understanding comes primarily through doing, much less so through explanations.
The explanations are only there so that the student can do what needs to be done.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

We want to allow students to start writing code immediately, without having to understand everything up front.
In order to achieve this we hand-wave over details and we leave a lot of things unexplained.
We simplify where possible and we provide code stubs.
We simplify and provide code stubs where possible.
This reduces the cognitive burden of getting started and provides the time and space for the knowledge to sink in.
By taking this approach we're not saying that the student doesn't need to know these things, we're saying that they don't need to know them _yet_.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

## Basic structure

Exercises are structured as a graph.
Exercises are structured as a tree with an introductory exercise at the top as the starting point.
Later exercises teach concepts that depend on having understood concepts that are taught earlier.

## Porting and borrowing

It can be worth looking at how other language tracks have built out their concept exercises.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved
You can find examples of Concept Exercises from other language tracks [here](https://exercism.org/docs/building/tracks/stories).

That said, if you decide to use other exercises as a starting point for your own, be careful to ensure that the resulting exercise is about the concept as it exists in your language.
Sometimes concepts differ subtly, sometimes radically.
Sometimes concepts don't exist at all.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved
Expand All @@ -40,6 +56,19 @@ It's better to ask up front or while working on an exercise rather than discussi

## Getting started

Our experience has taught us that the most pragmatic way to develop a syllabus is to grow the concept tree organically, starting with the simplest concepts.
We don't have to get everything right up front, but it's really useful to not think too far ahead.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

We start with concepts that are easy.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

Some things are easy because they are inherently simple.
Other things are not all that simple, but feel easy because they are familiar.
Familiar is good.
Familiar is not confusing.

While the endpoint is to write idiomatic code, the stepping stones to get there are not always idiomatic.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved
Using what is familiar—even if it is not a great example of code in that language—helps move a student more quickly toward the goal of code that is more typical of the language.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

### Developing the first exercise

Rather than trying to map out the entire concept tree up front, just start with the first exercise.
Expand Down Expand Up @@ -67,6 +96,16 @@ As long as you start somewhere that seems reasonable, it will be fine.

Read more about what we think "reasonable" means in the context of [expanding the concept tree](/docs/building/tracks/syllabus/expanding.md).

## Do not convert practice exercises

A good Concept Exercise is extremely focused, and ideally teaches only one concept.
There will usually be only one expected approach to solving it.
This is in contrast to Practice Exercises, which are open ended and lend themselves to exploration.

A good Concept Exercise is usually a bad Practice Exercise, and vice versa.
Since the goals of Practice Exercises and Concept Exercises are completely different, we do not take Practice Exercises and convert them into Concept Exercises.
We write all Concept Exercises from scratch or base them on stories that were explicitly crafted for the purpose of teaching simple concepts.

## We encourage handwaving
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

Sometimes you'll feel like there is a deadlock.
Expand Down
8 changes: 4 additions & 4 deletions building/tracks/syllabus/first-exercise.md
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
# Syllabus - The first exercise

The first exercise should be called `basics`, and it should have no prerequisites.
It should teach only the most basic concepts needed in order to do anything in the language.
The first exercise should cover the concept `basics`, and it should have no prerequisites.
It should provide only enough information to allow the student to solve the exercise at hand.

For example, if you need to compile a program to get it to work, this is something that you'll want to mention in the introduction to the exercise.

Other things that are often covered within `basics` are:
Other things that are often covered within the `basics` exercise are:
- function or method definitions
- calling functions
- passing arguments to functions
Expand All @@ -15,7 +15,7 @@ Use as few data types as possible.
If you can manage, use only integers, as their notation is the same across most languages and will be well known to virtually everyone.

Each language is different, and you might find that you need to introduce more than other tracks do, or less.
Many tracks have already implemented a `basics` exercise.
Many tracks have already implemented an exercise covering `basics`.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved
If there's a track for a language that is similar to yours, go ahead and check if you can fork their exercise and use it as a starting point.

Aim to be concise; you don't want to overload students with information.
Expand Down
13 changes: 9 additions & 4 deletions building/tracks/syllabus/next-exercises.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,7 @@ Having implemented your first concept exercise, the next few exercises should bu
We like to have three to five exercises that have no other prerequisites other than the `basics` concept.
kytrinyx marked this conversation as resolved.
Show resolved Hide resolved

Good options are the core primitives or data types of your language.
E.g. booleans, basic numeric types, strings, dates, and atoms.

Other good options are core concepts such as conditionals, loops, and basic arithmetic.
E.g. booleans, basic numeric types, strings, and atoms.

It's worth checking other tracks' concept exercises to see if there are any that are appropriate for your track.

Expand All @@ -17,11 +15,18 @@ The language might have a dozen different numeric types that are useful in diffe
The exercise can simply mention that there are others while introducing only the most commonly used integer type and most commonly used floating-point type.

Some core data types are too complex to introduce directly.
For example strings might be lists of chars, in which case you'd want to introduce both chars and lists separately before introducing strings.
For example strings might be lists of chars.
In such a case you would need to defer the introduction of strings, and design a concept exercise for chars and another for lists.
Then you can add an exercise for strings that has both of those exercises as prerequisites.

Sometimes while working on an exercise you will realize that it's more complex than you expected.
That's totally fine.
Make a note of the concept that needs to be taught as a prerequisite.
Then pretend that such an exercise exists, and finish the exercise you're working on with that simplification in mind.
Then go back and create a new exercise for the prerequisite concept.
Remember to mark the exercise as `wip` until the prerequisite exercise has been added.

Another thing that can happen at this point is that you find that you have cyclical dependencies.
You need to introduce two concept, but each concept relies on the other.
In this case you may be able to use a stub.
Then you can explain that the dependent concept exists, but reassure them that they don't need to understand it yet.