generated from amosproj/amos202Xss0Y-projname
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #238 from amosproj/dev
Final sprint release
- Loading branch information
Showing
79 changed files
with
2,979 additions
and
1,543 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
# SPDX-License-Identifier: MIT | ||
# SPDX-FileCopyrightText: 2023 Berkay Bozkurt <[email protected]> | ||
|
||
name: documentation | ||
|
||
on: [push, pull_request, workflow_dispatch] | ||
|
||
permissions: | ||
contents: write | ||
|
||
jobs: | ||
docs: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Set up Python 3.10 | ||
uses: actions/setup-python@v4 | ||
with: | ||
python-version: "3.10" | ||
- name: Install dependencies | ||
run: | | ||
python -m pip install --upgrade pip | ||
pip install pipenv | ||
# if [ -f requirements.txt ]; then pip install -r requirements.txt; fi | ||
pipenv install --dev | ||
- name: Generate Sphinx | ||
run: | | ||
cd src/docs | ||
pipenv run sphinx-apidoc -o . .. | ||
pipenv run make clean | ||
pipenv run make html | ||
- name: Deploy to GitHub Pages | ||
uses: peaceiris/actions-gh-pages@v3 | ||
if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/main' }} | ||
with: | ||
publish_branch: gh-pages | ||
github_token: ${{ secrets.GITHUB_TOKEN }} | ||
publish_dir: src/docs/_build/html/ | ||
force_orphan: true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
# Automatic SBOM generation | ||
|
||
```console | ||
pipenv install | ||
pipenv shell | ||
|
||
pip install pipreqs | ||
pip install cyclonedx-bom | ||
pip install pip-licenses | ||
|
||
# Create the SBOM (cyclonedx-bom) based on (pipreqs) requirements that are actually imported in the .py files | ||
|
||
$sbom = pipreqs --print | cyclonedx-py -r -pb -o - -i - | ||
|
||
# Create an XmlDocument object | ||
$xml = New-Object System.Xml.XmlDocument | ||
|
||
# Load XML content into the XmlDocument | ||
$xml.LoadXml($sbom) | ||
|
||
|
||
# Create an empty CSV file | ||
$csvPath = "SBOM.csv" | ||
|
||
# Initialize an empty array to store rows | ||
$result = @() | ||
|
||
# Iterate through the XML nodes and create rows for each node | ||
$xml.SelectNodes("//*[local-name()='component']") | ForEach-Object { | ||
|
||
$row = @{ | ||
"Version" = $_.Version | ||
"Context" = $_.Purl | ||
"Name" = if ($_.Name -eq 'scikit_learn') { 'scikit-learn' } else { $_.Name } | ||
} | ||
|
||
# Get license information | ||
$match = pip-licenses --from=mixed --format=csv --with-system --packages $row.Name | ConvertFrom-Csv | ||
|
||
# Add license information to the row | ||
$result += [PSCustomObject]@{ | ||
"Context" = $row.Context | ||
"Name" = $row.Name | ||
"Version" = $row.Version | ||
"License" = $match.License | ||
} | ||
} | ||
|
||
# Export the data to the CSV file | ||
$result | Export-Csv -Path $csvPath -NoTypeInformation | ||
|
||
# Create the license file | ||
$licensePath = $csvPath + '.license' | ||
@" | ||
SPDX-License-Identifier: CC-BY-4.0 | ||
SPDX-FileCopyrightText: 2023 Fabian-Paul Utech <[email protected]> | ||
"@ | Out-File -FilePath $licensePath | ||
|
||
exit | ||
|
||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
<!-- | ||
SPDX-License-Identifier: MIT | ||
SPDX-FileCopyrightText: 2024 Felix Zailskas <[email protected]> | ||
--> | ||
|
||
# Unused Ideas | ||
|
||
This document lists ideas and implementations which have either not been tried yet or have been deprecated as they are not used in the current product version but still carry some conceptual value. | ||
|
||
## Deprecated | ||
|
||
The original implementation of the deprecated modules can be found in the `deprecated/` directory. | ||
|
||
### Controller | ||
|
||
**_Note:_** This package has the additional dependency `pydantic==2.4.2` | ||
|
||
The controller module was originally planned to be used as a communication device between EVP and BDC. Whenever the salesperson interface would register a new lead the controller is supposed to trigger the BDC pipeline to enrich the data of that lead and preprocess it to create a feature vector. The successful completion of the BDC pipeline is then registered at the controller which will then trigger an inference of the EVP to compute the predicted merchant size and write this back to the lead data. The computed merchant size can then be used to rank the leads and allow the salesperson to decide the value of the leads and which one to call. | ||
|
||
The current implementation of the module supports queueing messages from the BDC and EVP as indicated by their type. Depending on the message type the message is then routed to the corresponding module (EVP or BDC). The actual processing of the messages by the modules is not implemented. All of this is done asynchronously by using the python threading library. | ||
|
||
### FacebookGraphAPI | ||
|
||
**_Note:_** This package has the additional dependency `facebook-sdk==3.1.0`. Also the environment variables `FACEBOOK_APP_ID` `FACEBOOK_APP_SECRET` need to be set with a valid token. | ||
|
||
This step was supposed to be used for querying lead data from the facebook by using either the business owner's name or the company name. The attempt was deprecated as the cost for the needed API token was evaluated too high and because the usage permissions of the facebook API were changed. Furthermore, it is paramount to check the legal ramifications of querying facebook for this kind of data as there might be legal consequences of searching for individuals on facebook instead of their businesses due to data privacy regulations in the EU. | ||
|
||
### ScrapeAddresses | ||
|
||
This step was an early experiment, using only the custom domain from an email address. We check if there's a live website running | ||
for the domain, and then try to parse the main site for a business address using a RegEx pattern. The pattern is not very precise | ||
and calling the website, as well as parsing it, takes quite some time, which accumulates for a lot of entries. The Google places | ||
step yields better results for the business address and is faster, that's why `scrape_addresses.py` was deprecated. | ||
|
||
## Possible ML improvements | ||
|
||
### Creating data subsets | ||
|
||
The data collected by the BDC pipeline has not been refined to only include semantically valuable data fields. It is possible that some data fields contain no predictive power. This would mean they are practically polluting the dataset with unnecessary information. A proper analysis of the predictive power of all data fields would allow cutting down on the amount of data for each lead, reducing processing time and possibly make predictions more precise. This approach has been explored very briefly by the subset 1 as described in `Classifier-Comparison.md`. However, the choice of included features has not been justified by experiments making them somewhat arbitrary. Additionally, an analysis of this type could give insights on which data fields to expand on and what new data one might want to collect to increase the EVP's performance in predicting merchant sizes. | ||
|
||
Possibly filtering data based on some quality metric could also improve general performance. The regional_atlas_score and google_confidence_score have been tried for this but did not improve performance. However, these values are computed somewhat arbitrarily and implementing a more refined quality metric might result in more promising results. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.