j-js commited on
Commit
349472f
·
verified ·
1 Parent(s): fa63512

Create solver_distance_rate_time.py

Browse files
Files changed (1) hide show
  1. solver_distance_rate_time.py +64 -0
solver_distance_rate_time.py ADDED
@@ -0,0 +1,64 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from __future__ import annotations
2
+
3
+ import re
4
+ from typing import Optional
5
+
6
+ from models import SolverResult
7
+
8
+
9
+ def solve_distance_rate_time(text: str) -> Optional[SolverResult]:
10
+
11
+ lower = text.lower()
12
+
13
+ if "speed" not in lower and "distance" not in lower:
14
+ return None
15
+
16
+ nums = [float(x) for x in re.findall(r"\d+(?:\.\d+)?", lower)]
17
+
18
+ if len(nums) < 2:
19
+ return None
20
+
21
+ # simple pattern: speed and time given
22
+ if "speed" in lower and "time" in lower:
23
+
24
+ speed = nums[0]
25
+ time = nums[1]
26
+
27
+ distance = speed * time
28
+
29
+ return SolverResult(
30
+ domain="quant",
31
+ solved=True,
32
+ topic="distance_rate_time",
33
+ answer_value=f"{distance:g}",
34
+ internal_answer=f"{distance:g}",
35
+ steps=[
36
+ "Use the formula distance = speed × time.",
37
+ f"Multiply {speed} by {time}."
38
+ ]
39
+ )
40
+
41
+ # simple pattern: distance and speed given
42
+ if "distance" in lower and "speed" in lower:
43
+
44
+ distance = nums[0]
45
+ speed = nums[1]
46
+
47
+ if speed == 0:
48
+ return None
49
+
50
+ time = distance / speed
51
+
52
+ return SolverResult(
53
+ domain="quant",
54
+ solved=True,
55
+ topic="distance_rate_time",
56
+ answer_value=f"{time:g}",
57
+ internal_answer=f"{time:g}",
58
+ steps=[
59
+ "Use the formula time = distance ÷ speed.",
60
+ f"Divide {distance} by {speed}."
61
+ ]
62
+ )
63
+
64
+ return None