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

Issue with re(learning) steps #13

Open
tomerbeil opened this issue May 2, 2024 · 3 comments
Open

Issue with re(learning) steps #13

tomerbeil opened this issue May 2, 2024 · 3 comments

Comments

@tomerbeil
Copy link
Contributor

tomerbeil commented May 2, 2024

Hi! I’ve noticed some differences between Anki’s FSRS and Swift FSRS.

In Anki, with FSRS turned on and default settings, the due date in the first review for “Again” button is 1 minute, for “Good” button — 10 minutes. This behavior is identical to the Swift version of the algorithm. However, there are changes after the first rating.

In Anki with FSRS, if I tap on “Again” button in the first review, in my next review the intervals for all ratings stay the same (1 minute for “Again”, 10 minutes for “Good). In Swift version of the algorithm, if I tap on “Again” button in the first review, in my next review the interval will be different (5 minutes for “Again”, 1 day for “Good).

The same situation with relearning. If I tap on the 'Again' button for the card with status 'review', in the next review the new interval for “Good” should be 10 minutes, not an interval in days.

I consider these as important issues. From Anki Manual:

«When you press Again, the card goes back to first step, and will be shown again approximately 1 minute later»
«When you forget a review card, it is said to have 'lapsed', and the card must be relearnt. The default behaviour for lapsed reviews is to reset the interval to 1 (i.e. make it due tomorrow), and put it in the learning queue for a refresher in 10 minutes.»

Since I’m almost completely beginner in programming, it’s quite hard for me to find the reason in the code. So I would appreciate if someone can verify this problem and resolve it. Thank you very much!

@ishiko732
Copy link
Contributor

case .new:
initDS(s: &s)
s.again.due = s.addTime(now, value: 1, unit: .minute)
s.hard.due = s.addTime(now, value: 5, unit: .minute)
s.good.due = s.addTime(now, value: 10, unit: .minute)
let easyInterval = nextInterval(s: s.easy.stability)
s.easy.scheduledDays = easyInterval
s.easy.due = s.addTime(now, value: easyInterval, unit: .day)

again.due = addTime(now, value: 5, unit: .minute)
if hardInterval > 0 {
hard.due = addTime(now, value: hardInterval, unit: .day)
} else {
hard.due = addTime(now, value: 10, unit: .minute)
}

When a card with State.New is clicked Again or Hard, it will change to State.Learning, and the due time will increase from 1 to 5 minutes.
image
image

After a card changes from State.New to State.Learning, if Again is clicked again, it sets the interval to 5 minutes. I'm not sure if this is a bug or not, and I would like @L-M-Sherlock to confirm. Personally, I don't think whether it's 1 minute or 5 minutes would make much of a difference.

@tomerbeil
Copy link
Contributor Author

@ishiko732 Thank you for the explanation!

1 minute or 5 minutes for the "Again" button — it really doesn't make much of a difference. However, as I mentioned earlier, the interval for the "Good" button in this case (when the user pressed "Again" last time) could be 1 day or more when it should be 10 minutes (because the card should have gone back to the first learning step earlier).

I don't know whether it's possible to track and change the learning step while the card is in the "learning" or "relearning" status because there isn't something like a "learningStep" field in the Card mode.

@L-M-Sherlock
Copy link
Member

I don't want to implement the learning steps of Anki, because it's too complex. So the current implementation is a simple version. It even doesn't have the conception of learning steps.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants