#!/bin/bash
# Quick verification script to check if all dependencies are available

echo "Checking L5PC comparison setup..."
echo ""

# Check virtual environment
if [ -d "../venv" ]; then
    echo "✓ Virtual environment found at ../venv"
else
    echo "✗ Virtual environment NOT found at ../venv"
    exit 1
fi

# Check HelioX library
if [ -d "$HOME/Documents/heliox/python_lib" ]; then
    echo "✓ HelioX library found"
else
    echo "✗ HelioX library NOT found at $HOME/Documents/heliox/python_lib"
    exit 1
fi

# Check HOC files
if [ -f "L5PClatemplate_record.hoc" ] && [ -f "L5PClatemplate_passive.hoc" ]; then
    echo "✓ HOC template files found"
else
    echo "✗ HOC template files missing"
    exit 1
fi

# Check mod directory
if [ -d "mod" ]; then
    mod_count=$(ls mod/*.mod 2>/dev/null | wc -l)
    echo "✓ Mod directory found with $mod_count .mod files"
else
    echo "✗ Mod directory missing"
    exit 1
fi

# Check Python scripts
if [ -f "run_save_traces.py" ] && [ -f "plot_compare_to_neuron.py" ]; then
    echo "✓ Run/save + plot/compare scripts found"
else
    echo "✗ Missing run_save_traces.py and/or plot_compare_to_neuron.py"
    exit 1
fi

# Activate venv and check NEURON
source ../venv/bin/activate
if python -c "import neuron" 2>/dev/null; then
    echo "✓ NEURON module can be imported"
else
    echo "✗ NEURON module cannot be imported"
    exit 1
fi

# Check if nrnivmodl is available
if command -v nrnivmodl &> /dev/null; then
    echo "✓ nrnivmodl compiler found"
else
    echo "✗ nrnivmodl compiler not found"
    exit 1
fi

echo ""
echo "All checks passed! You can run the comparison with:"
echo "  python run_save_traces.py --mode all --case demo --stim dend_69 --stim-pattern constant --amp 0.02"
echo "  python plot_compare_to_neuron.py --case demo"
echo ""
echo "Or (recommended for CoreNEURON):"
echo "  source ../venv/bin/activate"
echo "  export PYTHONPATH=\"$HOME/Documents/heliox/python_lib:\$PYTHONPATH\""
echo "  nrnivmodl mod  # First time only"
echo "  nrnivmodl -coreneuron mod  # For CoreNEURON comparison"
