File size: 1,004 Bytes
59bdcfe
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import pandas as pd
import numpy as np

class MockCropModel:
    def __init__(self):
        self.knowledge_base = {
            ('loamy', 'tropical'): ['Cassava', 'Banana', 'Rice'],
            ('clay', 'temperate'): ['Wheat', 'Potatoes', 'Barley'],
            ('sandy', 'arid'): ['Sorghum', 'Millet', 'Dates'],
            ('default', 'default'): ['Maize', 'Beans', 'Soybeans']
        }
    
    def predict(self, soil_type, climate):
        soil = soil_type.lower()
        climate = climate.lower()
        
        for key in self.knowledge_base:
            if soil in key[0] and climate in key[1]:
                crops = self.knowledge_base[key]
                break
        else:
            crops = self.knowledge_base[('default', 'default')]
        
        confidences = np.linspace(0.9, 0.7, num=len(crops))
        return pd.DataFrame({
            'Crop': crops,
            'Confidence': confidences,
            'Soil Type': soil_type,
            'Climate Zone': climate
        })