File size: 5,721 Bytes
7b851dd
 
 
 
 
 
 
 
debbbde
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
---
language:
- en
pipeline_tag: text-generation
tags:
- Python
- assistant
- code
---

This is proof of concept to see how far LLM's on the smaller side can go when fine-tuned for code generation and understanding.   
The base model is based on OpenLlama-3b and can be found [here](https://huggingface.co/psmathur/orca_mini_3b) and it has been trained using [axolotl](https://github.com/OpenAccess-AI-Collective/axolotl/tree/main).

Next I'll show some examples of what the model is currently capable of.
I have edited the quotes to be able to show the prompts correctly here the model outputs proper markdown.

The first sample shows a non-trivial example of the model generating code.
(Depending on the complexity of the required task the generated code might not work. For example, making the model write code to move the square
around has proven to be quite difficult.)
```
Below is an instruction that describes a task. Write a response that appropriately completes the request.

### Instruction:
Write Python code to draw a square on the screen using Pygame.

### Response:
Sure, here's a Python code to draw a square on the screen using PyGame.
'''python
import pygame

pygame.init()
window = pygame.display.set_mode((800, 600))

def draw(x, y):
  pygame.draw.rect(window, (255, 170, 170), [x, y, 50, 50])

running = True
while running:
  for event in pygame.event.get():
    if event.type == pygame.QUIT:
      running = False

  # Clear the screen
  window.fill((0, 0, 0))
  
  # Draw a square
  x, y = 40, 30
  draw(x, y)
  
  # Update the display
  pygame.display.flip()
'''
```

Next there are a few samples to show how the model understands the code.
In this first example the model is able to answer correctly what shape is being drawn and even tells the position correctly,
it gets the color wrong in this case
```
Below is an instruction that describes a task. Write a response that appropriately completes the request.

### Instruction:
What shape does the following code draw on the screen?
import pygame

pygame.init()
window = pygame.display.set_mode((800, 600))

def draw(x, y):
  pygame.draw.rect(window, (255, 170, 170), [x, y, 50, 50])

running = True
while running:
  for event in pygame.event.get():
    if event.type == pygame.QUIT:
      running = False

  # Clear the screen
  window.fill((0, 0, 0))
  
  # Draw a square
  x, y = 40, 30
  draw(x, y)
  
  # Update the display
  pygame.display.flip()

### Response:
The code will draw a red square at position (40, 30).
```

To the question about how to improve the code the model answers by adding code to limit the number of frames per second.
```
Below there are some samples generated by the model:
Below is an instruction that describes a task. Write a response that appropriately completes the request.

### Instruction:
How could you improve the following code?

'''python
import pygame
from pygame.locals import *

pygame.init()
window = pygame.display.set_mode((800, 600))

def main():
done = False

while not done:
  for event in pygame.event.get():
    if event.type == QUIT:
      done = True

  # Clear the screen
  window.fill((0, 0, 0))
  
  # Draw the square
  x, y = 150, 140
  pygame.draw.rect(window, (255, 0, 0), [x, y, 50, 50])
  
  # Update the display
  pygame.display.flip()

if __name__ == '__main__':
  main()
'''

### Response:
You can use `pygame.time.Clock` to control the frames per second and limit the number of frames to prevent
your program from freezing. Here's a modified version of your code with this addition:

'''python
import pygame
from pygame.locals import *

pygame.init()
window = pygame.display.set_mode((800, 600))
clock = pygame.time.Clock()

def main():
done = False

targetFPS = 30
currentFPS = clock.tick(targetFPS) / targetFPS
maxFrames = int(currentFPS * 60) + 1
while not done:
  for event in pygame.event.get():
    if event.type == QUIT:
      done = True

  # Limit frames to targetFPS
  if currentFPS > targetFPS:
    currentFPS = targetFPS
    maxFrames = min(maxFrames, targetFPS * 60)
  
  # Clear the screen
  window.fill((0, 0, 0))
  
  # Draw the square
  x, y = 150, 140
  pygame.draw.rect(window, (255, 0, 0), [x, y, 50, 50])
  
  # Update the display
  pygame.display.flip()

if __name__ == '__main__':
  main()
'''
```

Finally a example in which the model completely hallucinates the answer. It's an easy leetcode problem.
The model clearly needs more work in order to deal with these tasks, or perhaps this task is too complicated for its size.
```
Below is an instruction that describes a task, paired with an input that provides further context. Write a response that appropriately completes the request.

### Instruction:
Solve the following problem using Python 3. Write only the code.

### Input:
Given an array of integers nums and an integer target, return indices of the two numbers such that they add up to target.

You may assume that each input would have exactly one solution, and you may not use the same element twice.

You can return the answer in any order.


Example 1:

Input: nums = [2,7,11,15], target = 9
Output: [0,1]
Explanation: Because nums[0] + nums[1] == 9, we return [0, 1].

Example 2:

Input: nums = [3,2,4], target = 6
Output: [1,2]

Example 3:

Input: nums = [3,3], target = 6
Output: [0,1]



Constraints:

2 <= nums.length <= 10^4
-10^9 <= nums[i] <= 10^9
-10^9 <= target <= 10^9
Only one valid answer exists.



### Response:
Certainly, here is one potential way to implement a function in Python 3 that effectively solves the problem.
'''python
class Solution:
def twoSum(self, A: List[int], T: int) -> List[int]:
ans = []
for x in range(len(A)-1):
  if A[x]+A[x+1] == T:
    ans.append(x)
  else:
    ans.append(x+1)
return ans
'''
```