Welcome to Solunar Bass, an open-source project by Bassfinity that helps bass fishermen maximize their fishing success using solunar theory, data acquisition, and personalized recommendations. This repository powers a web app that predicts optimal bass fishing times based on solunar data, weather conditions, and location. You can view the website here
The project consists of several key components working together, from data acquisition to recommendations.
This repository contains all the necessary components to run the Solunar Bass web application:
- app.py: The main application file that integrates all functionalities and renders the Streamlit web interface.
- src/: A directory containing all the modules:
- data_acquisition.py: Handles fetching and processing external data (e.g., weather, solunar events) required for accurate predictions.
- data_processing.py: Responsible for cleaning, transforming, and structuring data for analysis and display.
- solunar_calculations.py: Provides utility functions for calculating solunar tables, lunar phases, and their impact on fishing activity.
- recommendation_engine.py: Contains the logic to generate personalized fishing recommendations based on solunar data and user input.
- requirements.txt: Lists all the Python dependencies needed to run the application.
- README.md: Provides an overview and instructions for setting up the project.
The application is hosted via Streamlit, allowing it to be easily deployed and accessed via the web.
- Real-time Solunar Calculations: Uses solunar theory to predict peak times for bass fishing.
- Location-based Forecasts: Enter your location or use your current geolocation to get localized fishing forecasts.
- User-friendly Interface: Built using Streamlit for an intuitive and visually appealing user experience.
- Interactive Map: Powered by Folium, showing your selected location.
To run this application locally, you'll need:
- Python 3.7 or higher
- pip (Python package installer)
- The dependencies listed in the
requirements.txt
file
Open your terminal or command prompt and run:
git clone https://github.com/bassfinity/solunarbass.git
cd solunarbass
Creating a virtual environment is recommended to avoid conflicts with system-wide Python packages.
-
On macOS/Linux:
python3 -m venv venv
-
On Windows:
python -m venv venv
-
On macOS/Linux:
source venv/bin/activate
-
On Windows (Command Prompt):
venv\Scripts\activate.bat
-
On Windows (PowerShell):
venv\Scripts\Activate.ps1
Note: If you encounter an error regarding script execution policies in PowerShell, you may need to adjust the execution policy:
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser
Ensure you have the latest version of pip
:
python -m pip install --upgrade pip
Install the necessary Python libraries with the following command:
python -m pip install -r requirements.txt
The application requires an API key from Visual Crossing Weather to fetch weather and astronomical data.
Follow these steps to set up your API_KEY
:
-
Sign Up for an API Key
- Visit the Visual Crossing Weather API website.
- Sign up for a free account to obtain your API key.
-
Create a
config.toml
File-
In the root directory of the project (where
app.py
is located), create a file namedconfig.toml
.-
On macOS/Linux:
nano config.toml
-
On Windows:
- Open a text editor (e.g., Notepad) and create a new file named
config.toml
.
- Open a text editor (e.g., Notepad) and create a new file named
-
-
Add the following content to
config.toml
, replacing"your_visual_crossing_api_key"
with the API key you obtained:# config.toml API_KEY = "your_visual_crossing_api_key"
-
Save and close the file.
-
-
Secure Your API Key
-
Important: To prevent accidentally committing your API key to version control, add
config.toml
to your.gitignore
file.echo "config.toml" >> .gitignore
-
With all the setup complete, you can now run the application:
streamlit run app.py
This will launch the web app locally, and you can access it in your browser at http://localhost:8501
.
-
API Key Setup:
The application relies on the
API_KEY
provided in theconfig.toml
file to fetch necessary data. Ensure that theAPI_KEY
is correctly set up as per the instructions. -
Virtual Environment:
Using a virtual environment isolates the project's dependencies, preventing conflicts with other Python projects or system-wide packages.
-
Dependencies:
The required Python packages are listed in the
requirements.txt
file:streamlit pandas numpy requests pytz streamlit-js-eval folium streamlit-folium toml
Note: The
toml
library is required for reading theconfig.toml
file.
This is the entry point for the web app. It ties together data acquisition, processing, solunar calculations, and the recommendation engine. The user interface is built with Streamlit, providing options to input location, select date, and display results.
This module handles fetching data from external APIs (e.g., weather data). It ensures that relevant data points, such as moon phases and weather conditions, are retrieved and prepared for processing.
-
Key Functions:
get_solunar_data(lat, lon, date)
: Fetches solunar and weather information for the specified location and date.
-
API Key Retrieval:
The
API_KEY
is retrieved from theconfig.toml
file using a function that ensures the key is securely and consistently accessed.
This script processes the raw data obtained from the data acquisition step. It ensures data is clean, correctly formatted, and ready for analysis.
-
Key Functions:
process_solunar_data(data, date_str)
: Cleans and formats raw data for use in calculations.
This module contains the logic to compute solunar events, such as major and minor feeding times, based on the moon's position.
-
Key Functions:
calculate_major_minor_times(solunar_data)
: Calculates major and minor periods for fishing activity.
This module uses solunar theory to recommend the best times for bass fishing.
-
Key Functions:
generate_recommendations(major_times, minor_times)
: Generates personalized fishing recommendations.
You can now run the Solunar Bass Forecasting Tool using Docker. Follow the steps below to build and run the Docker container.
- Install Docker on your system.
-
Pull the Prebuilt Image The Docker image is available on Docker Hub. Pull it using:
docker pull anuclei/solunarbass:latest
-
Run the Container Start the container and map the appropriate ports:
docker run -p 8501:8501 anuclei/solunarbass:latest
-
Access the Application Open your browser and navigate to:
http://localhost:8501
If you want to build the image yourself:
-
Clone the Repository
git clone https://github.com/bassfinity/solunarbass.git cd solunarbass
-
Build the Image Use the following command to build the Docker image:
docker build -t anuclei/solunarbass:latest .
-
Run the Container
docker run -p 8501:8501 anuclei/solunarbass:latest
If you perfer to pull the image from docker hub, you can use the following image
Contributions are welcome! If you want to contribute to the project, follow these steps:
-
Fork the repository.
-
Create a new branch for your feature or bug fix.
-
Make your changes and ensure everything is tested.
-
Open a pull request, and we will review it.
This project is licensed under the MIT License. See the LICENSE file for details.
For any questions or feedback, feel free to reach out to the Bassfinity team. You can also open an issue on the GitHub repository or contact us via email at [email protected].
🎧 Join the SolunarBass Community on Discord
We now have a dedicated #solunarbass channel in the Bassfinity Discord server! Join our community to discuss solunar theory, share fishing experiences, and collaborate on improving the SolunarBass tool. Whether you're a developer, an angler, or both, we'd love to have you.
- Discord Invite: Join our Discord and find us in the #solunarbass channel.
Special thanks to Visual Crossing for providing the weather data used in this application. Their comprehensive and reliable weather API was essential in building the forecasting functionality for this project.
Happy Fishing! 🐟