['3c3', "< Abstract: Self-correction is a highly desirable capability of large language models (LLMs), yet it has consistently been found to be largely ineffective in modern LLMs. Current methods for training self-correction typically depend on either multiple models, a more advanced model, or additional forms of supervision. To address these shortcomings, we develop a multi-turn online reinforcement learning (RL) approach, SCoRe, that significantly improves an LLM's self-correction ability using entirely self-generated data. To build SCoRe, we first show that variants of supervised fine-tuning (SFT) on offline model-generated correction traces are often insufficient for instilling self-correction behavior. In particular, we observe that training via SFT falls prey to either a distribution mismatch between mistakes made by the data-collection policy and the model's own responses, or to behavior collapse, where learning implicitly prefers only a certain mode of correction behavior that is often not effective at self-correction on test problems. SCoRe addresses these challenges by training under the model's own distribution of self-generated correction traces and using appropriate regularization to steer the learning process into learning a self-correction behavior that is effective at test time as opposed to fitting high-reward responses for a given prompt. This regularization process includes an initial phase of multi-turn RL on a base model to generate a policy initialization that is less susceptible to collapse, followed by using a reward bonus to amplify self-correction. With Gemini 1.0 Pro and 1.5 Flash models, we find that SCoRe achieves state-of-the-art self-correction performance, improving the base models' self-correction by 15.6% and 9.1% respectively on MATH and HumanEval.", '---', "> Abstract: Self-correction is a critical yet elusive capability for large language models (LLMs). Existing training methods often rely on multiple models, a more powerful model, or external supervision, limiting their practical application and effectiveness. We introduce SCoRe (Self-Correction via Reinforcement Learning), a novel multi-turn online reinforcement learning approach that significantly enhances an LLM's intrinsic self-correction ability using only self-generated data. We first demonstrate that supervised fine-tuning (SFT) on offline correction traces is insufficient, frequently leading to distribution mismatch or behavior collapse where models fail to learn robust self-correction. SCoRe overcomes these limitations by training directly on the model's own distribution of self-generated correction traces, employing a two-stage regularization process. This includes an initial multi-turn RL phase for a collapse-resistant policy initialization and a subsequent reward shaping mechanism to amplify true self-correction progress. Evaluated with Gemini 1.0 Pro and 1.5 Flash models, SCoRe achieves state-of-the-art self-correction performance, yielding absolute improvements of 15.6% on MATH and 9.1% on HumanEval over base models.", '113c113', '< Problem: def cycpattern_check(a , b): """You are given 2 words. You need to return True if the second word or any of its rotations is a substring in the first word cycpattern_check("abcd","abd") => False cycpattern_check("hello","ell") => True cycpattern_check("whassup","psus") => False cycpattern_check("abab","baa") => True cycpattern_check("efef","eeff") => False if int_digit % 2 == 0: even_count += 1 else:', '---', '> Problem: def cycpattern_check(a , b): \\"\\"\\"You are given 2 words. You need to return True if the second word or any of its rotations is a substring in the first word cycpattern_check("abcd","abd") => False cycpattern_check("hello","ell") => True cycpattern_check("whassup","psus") => False cycpattern_check("abab","baa") => True cycpattern_check("efef","eeff") => False if int_digit % 2 == 0: even_count += 1 else:', '115,116c115,116', '< Turn 2 solution (correct): def even_odd_count(num): """Given an integer. return a tuple that has the number of even and odd digits respectively.', '< Example: even_odd_count(-12) ==> (1, 1) even_odd_count( 123) ==> (1, 2) """ even_count = 0 odd_count = 0 for digit in str(abs(num)): int_digit = int(digit) if int_digit % 2 == 0: even_count += 1 else:', '---', '> Turn 2 solution (correct): def even_odd_count(num): \\"\\"\\"Given an integer. return a tuple that has the number of even and odd digits respectively.', '> Example: even_odd_count(-12) ==> (1, 1) even_odd_count( 123) ==> (1, 2) \\"\\"\\" even_count = 0 odd_count = 0 for digit in str(abs(num)): int_digit = int(digit) if int_digit % 2 == 0: even_count += 1 else:', '195c195', '< Alternatively, from RL literature, one could theoretically characterize self-correction policies under the notion of adaptive policies. These adaptive policies condition action predictions not only on the current state but also on past attempts or previous episodes. It is known in the RL literature that such adaptive policies especially excel in generalization settings. For example, the benefits of adaptive policies are studied by Ghosh et al. (2021). The sequential classification setting in this paper is conceptually similar to self-correction (though not the same). """You are given 2 words. You need to return True if the second word or any of its rotations is a substring in the first word cycpattern_check("abcd","abd") => False cycpattern_check("hello","ell") => True cycpattern_check("whassup","psus") => False cycpattern_check("abab","baa") => True cycpattern_check("efef","eeff") => False cycpattern_check("himenss","simen") => True """You are given 2 words. You need to return True if the second word or any of its rotations is a substring in the first word cycpattern_check("abcd","abd") => False cycpattern_check("hello","ell") => True cycpattern_check("whassup","psus") => False cycpattern_check("abab","baa") => True cycpattern_check("efef","eeff") => False cycpattern_check("himenss","simen") => True ', '---', '> Alternatively, from RL literature, one could theoretically characterize self-correction policies under the notion of adaptive policies. These adaptive policies condition action predictions not only on the current state but also on past attempts or previous episodes. It is known in the RL literature that such adaptive policies especially excel in generalization settings. For example, the benefits of adaptive policies are studied by Ghosh et al. (2021). The sequential classification setting in this paper is conceptually similar to self-correction (though not the same). \\"\\"\\"You are given 2 words. You need to return True if the second word or any of its rotations is a substring in the first word cycpattern_check("abcd","abd") => False cycpattern_check("hello","ell") => True cycpattern_check("whassup","psus") => False cycpattern_check("abab","baa") => True cycpattern_check("efef","eeff") => False cycpattern_check("himenss","simen") => True \\"\\"\\"You are given 2 words. You need to return True if the second word or any of its rotations is a substring in the first word cycpattern_check("abcd","abd") => False cycpattern_check("hello","ell") => True cycpattern_check("whassup","psus") => False cycpattern_check("abab","baa") => True cycpattern_check("efef","eeff") => False cycpattern_check("himenss","simen") => True ', '202,205c202,205', '< """Given an integer. return a tuple that has the number of even and odd digits respectively.', '< Example: even_odd_count(-12) ==> (1, 1) even_odd_count( 123) ==> (1, 2) """ Turn 1 solution (incorrect): def even_odd_count(num):', '< """Given an integer. return a tuple that has the number of even and odd digits respectively.', '< Example: even_odd_count(-12) ==> (1, 1) even_odd_count( 123) ==> (1, 2) """ even_count = 0 odd_count = 0 for digit in str(num): int_digit = int(digit)', '---', '> \\"\\"\\"Given an integer. return a tuple that has the number of even and odd digits respectively.', '> Example: even_odd_count(-12) ==> (1, 1) even_odd_count( 123) ==> (1, 2) \\"\\"\\" Turn 1 solution (incorrect): def even_odd_count(num):', '> \\"\\"\\"Given an integer. return a tuple that has the number of even and odd digits respectively.', '> Example: even_odd_count(-12) ==> (1, 1) even_odd_count( 123) ==> (1, 2) \\"\\"\\" even_count = 0 odd_count = 0 for digit in str(num): int_digit = int(digit)', '400d399', '< ']
