File size: 12,290 Bytes
b7f3196
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
"""

End-to-End Healthcare Classification CLI



This provides a complete classification pipeline:

1. First classifies as "medical" or "insurance"

2. If medical, applies reason classification for detailed categorization



IMPORTANT: Activate virtual environment first!

Usage:

  source .venv/bin/activate

  python cli/healthcare_classifier_cli.py --interactive

"""

import argparse
import json
import sys
from pathlib import Path

# Add project root to path
REPO_ROOT = Path(__file__).resolve().parents[1]
if str(REPO_ROOT) not in sys.path:
    sys.path.insert(0, str(REPO_ROOT))

def classify_healthcare_query(query: str):
    """

    Complete healthcare query classification pipeline.

    

    Step 1: Medical vs Insurance classification

    Step 2: If medical, apply reason classification

    """
    
    print(f"Query: {query}")
    print("=" * 60)
    
    try:
        # Add classifier to path
        sys.path.append('classifier')
        
        # Step 1: Medical vs Insurance Classification
        print("πŸ” Step 1: Medical vs Insurance Classification")
        print("-" * 40)
        
        from infer import predict_query
        from utils import get_models
        
        # Load medical/insurance classifier
        embedding_model, classifier_head = get_models()
        
        # Get medical vs insurance prediction
        result = predict_query([query], embedding_model, classifier_head)
        
        primary_category = result['prediction'][0]
        confidence = result['confidence']
        if isinstance(confidence, list):
            confidence = confidence[0]
        
        print(f"Primary Classification: {primary_category.upper()}")
        print(f"Confidence: {confidence:.4f}")
        
        # Show probabilities
        probabilities = result['probabilities']
        if isinstance(probabilities[0], list):
            probabilities = probabilities[0]
        
        print("Probabilities:")
        from utils import CATEGORIES
        for i, category in enumerate(CATEGORIES):
            print(f"  {category}: {probabilities[i]:.4f}")
        
        # Step 2: If medical, apply reason classification
        if primary_category.lower() == 'medical':
            print(f"\nπŸ₯ Step 2: Medical Reason Classification")
            print("-" * 40)
            
            try:
                from classifier.reason.infer_reason import predict_single_reason
                
                reason_result = predict_single_reason(query)
                
                print(f"Medical Reason: {reason_result['category']}")
                print(f"Reason Confidence: {reason_result['confidence']:.4f}")
                
                print("Reason Probabilities:")
                sorted_probs = sorted(reason_result['probabilities'].items(), 
                                    key=lambda x: x[1], reverse=True)
                for category, prob in sorted_probs:
                    print(f"  {category}: {prob:.4f}")
                
                # Final routing decision
                print(f"\n🎯 Final Routing Decision")
                print("-" * 25)
                print(f"Route to: {reason_result['category']} Department")
                print(f"Overall confidence: Medical ({confidence:.3f}) β†’ {reason_result['category']} ({reason_result['confidence']:.3f})")
                
                return {
                    'primary_classification': primary_category,
                    'primary_confidence': confidence,
                    'reason_classification': reason_result['category'],
                    'reason_confidence': reason_result['confidence'],
                    'routing': f"{reason_result['category']} Department"
                }
                
            except Exception as e:
                print(f"⚠️  Reason classification failed: {e}")
                print("Note: Make sure reason classifier is trained")
                print(f"Routing to: General Medical Department")
                
                return {
                    'primary_classification': primary_category,
                    'primary_confidence': confidence,
                    'reason_classification': 'GENERAL_MEDICAL',
                    'reason_confidence': 0.0,
                    'routing': 'General Medical Department'
                }
        
        else:
            # Insurance query
            print(f"\nπŸ’³ Final Routing Decision")
            print("-" * 25)
            print(f"Route to: Insurance Department")
            print(f"Confidence: {confidence:.3f}")
            
            return {
                'primary_classification': primary_category,
                'primary_confidence': confidence,
                'reason_classification': None,
                'reason_confidence': None,
                'routing': 'Insurance Department'
            }
            
    except Exception as e:
        print(f"❌ Classification failed: {e}")
        if "No module named 'torch'" in str(e):
            print("\nπŸ”§ SOLUTION:")
            print("You need to activate the virtual environment first!")
            print("Run these commands:")
            print("  source .venv/bin/activate")
            print("  python cli/healthcare_classifier_cli.py --interactive")
        else:
            print("Note: Make sure models are trained and available")
        return None

def classify_batch_queries(queries_file: str, output_file: str = None):
    """Process multiple queries through the complete pipeline."""
    
    try:
        # Read queries
        with open(queries_file, 'r') as f:
            if queries_file.endswith('.json'):
                data = json.load(f)
                if isinstance(data, list):
                    queries = data
                else:
                    queries = data.get('queries', [])
            else:
                queries = [line.strip() for line in f if line.strip()]
        
        print(f"Processing {len(queries)} queries through complete pipeline...")
        print("=" * 60)
        
        results = []
        for i, query in enumerate(queries, 1):
            print(f"\nπŸ“‹ Query {i}/{len(queries)}")
            result = classify_healthcare_query(query)
            if result:
                result['query'] = query
                results.append(result)
            print()
        
        # Save results if output file specified
        if output_file:
            output_data = {
                'queries': queries,
                'predictions': results,
                'summary': {
                    'total_queries': len(queries),
                    'medical_queries': len([r for r in results if r['primary_classification'].lower() == 'medical']),
                    'insurance_queries': len([r for r in results if r['primary_classification'].lower() == 'insurance']),
                    'reason_categories': {}
                }
            }
            
            # Count reason categories
            for result in results:
                if result['reason_classification']:
                    cat = result['reason_classification']
                    output_data['summary']['reason_categories'][cat] = output_data['summary']['reason_categories'].get(cat, 0) + 1
            
            with open(output_file, 'w') as f:
                json.dump(output_data, f, indent=2)
            
            print(f"πŸ“„ Results saved to {output_file}")
        
        # Show summary
        medical_count = len([r for r in results if r['primary_classification'].lower() == 'medical'])
        insurance_count = len([r for r in results if r['primary_classification'].lower() == 'insurance'])
        
        print(f"\nπŸ“Š Summary:")
        print(f"  Medical queries: {medical_count} ({medical_count/len(results)*100:.1f}%)")
        print(f"  Insurance queries: {insurance_count} ({insurance_count/len(results)*100:.1f}%)")
        
        if medical_count > 0:
            reason_counts = {}
            for result in results:
                if result['reason_classification']:
                    cat = result['reason_classification']
                    reason_counts[cat] = reason_counts.get(cat, 0) + 1
            
            print(f"\n  Medical reason breakdown:")
            for category, count in sorted(reason_counts.items()):
                percentage = (count / medical_count) * 100
                print(f"    {category}: {count} queries ({percentage:.1f}%)")
            
    except Exception as e:
        print(f"❌ Error processing batch queries: {e}")
        return False
    
    return True

def interactive_mode():
    """Interactive mode for complete healthcare classification."""
    
    print("πŸ₯ Complete Healthcare Classification System")
    print("=" * 50)
    print("This system provides end-to-end classification:")
    print("  1️⃣  Medical vs Insurance classification")
    print("  2️⃣  Medical reason classification (if medical)")
    print("  3️⃣  Final routing decision")
    print()
    print("Enter healthcare queries to classify (type 'quit' to exit)")
    print()
    print("Example queries to try:")
    print("  Medical: 'I have heel pain when I walk'")
    print("  Medical: 'I need routine foot care'") 
    print("  Medical: 'I sprained my ankle'")
    print("  Insurance: 'My insurance claim was denied'")
    print("  Insurance: 'What does my insurance cover?'")
    print()
    
    while True:
        try:
            user_input = input("πŸ” Enter query >>> ").strip()
            
            if user_input.lower() == 'quit':
                print("πŸ‘‹ Goodbye!")
                break
            
            if user_input:
                classify_healthcare_query(user_input)
                print("\n" + "="*60)
            
        except KeyboardInterrupt:
            print("\nπŸ‘‹ Goodbye!")
            break
        except Exception as e:
            print(f"❌ Error: {e}")
            print()

def main():
    parser = argparse.ArgumentParser(
        description='Complete Healthcare Classification CLI',
        formatter_class=argparse.RawDescriptionHelpFormatter,
        epilog="""

Examples:

  # Interactive mode (recommended)

  python cli/healthcare_classifier_cli.py --interactive

  

  # Classify a single query

  python cli/healthcare_classifier_cli.py "I have heel pain"

  

  # Batch process queries from file

  python cli/healthcare_classifier_cli.py --batch queries.txt --output results.json



Pipeline:

  Query β†’ Medical/Insurance β†’ (if Medical) β†’ Reason Classification β†’ Routing

        """
    )
    
    parser.add_argument('query', nargs='?', help='Healthcare query to classify')
    parser.add_argument('--batch', type=str, help='File containing queries to process')
    parser.add_argument('--output', type=str, help='Output file for batch results')
    parser.add_argument('--interactive', action='store_true', 
                       help='Start interactive mode (recommended)')
    
    args = parser.parse_args()
    
    # Interactive mode
    if args.interactive:
        interactive_mode()
        return 0
    
    # Batch processing
    if args.batch:
        if not Path(args.batch).exists():
            print(f"❌ Error: Batch file does not exist: {args.batch}")
            return 1
        
        success = classify_batch_queries(args.batch, args.output)
        return 0 if success else 1
    
    # Single query processing
    if args.query:
        result = classify_healthcare_query(args.query)
        return 0 if result else 1
    
    # No arguments provided - show help and suggest interactive mode
    print("πŸ₯ Complete Healthcare Classification System")
    print("=" * 45)
    print("IMPORTANT: Activate virtual environment first!")
    print("  source .venv/bin/activate")
    print("  python cli/healthcare_classifier_cli.py --interactive")
    print()
    parser.print_help()
    return 1

if __name__ == "__main__":
    sys.exit(main())