diff --git a/README.md b/README.md
index ea54a1c6..66d210c2 100644
--- a/README.md
+++ b/README.md
@@ -1,4 +1,4 @@
-# Chirpity-Electron
+# Chirpity
Electron app to identify the calls of nocturnal migrants from audio files.
@@ -13,6 +13,11 @@ First, clone the project and install all dependencies:
```
git clone https://github.com/Mattk70/Chirpity-Electron
cd Chirpity-Electron
+```
+
+Chirpity depends on Node.js, follow the link for the download and installation instructions.
+Once installed, run:
+```
npm install
```
@@ -24,21 +29,21 @@ npm start
## Development setup
-Setting up the project requires Node.js, which we need to install first.
-After that, we can initialize the source directory with:
+
+Initialize the source directory with:
```
npm init
```
-Now, we need to install project dependencoies with:
+Now, install project dependencoies with:
```
npm install --save-dev
```
-After that, we can build a windows msi installer with:
+After that, build a windows msi installer with:
```
npm run export
diff --git a/js/ui.js b/js/ui.js
index 02f6fb47..2aa5e40c 100644
--- a/js/ui.js
+++ b/js/ui.js
@@ -1476,7 +1476,7 @@ window.onload = async () => {
speciesThreshold: config.speciesThreshold
});
loadModel();
- worker.postMessage({ action: 'clear-cache' })
+ //worker.postMessage({ action: 'clear-cache' })
// New users - show the tour
if (!config.seenTour) {
setTimeout(prepTour, 2000)
@@ -2191,7 +2191,7 @@ speciesThreshold.addEventListener('change', () =>{
worker.postMessage({ action: 'update-list', list: config.list })
})
-const loadModel = () => {
+const loadModel = ({clearCache = true} = {}) => {
t0_warmup = Date.now();
worker.postMessage({
action: 'load-model',
@@ -2200,7 +2200,8 @@ const loadModel = () => {
batchSize: config[config.backend].batchSize,
warmup: config.warmup,
threads: config[config.backend].threads,
- backend: config.backend
+ backend: config.backend,
+ clearCache: clearCache
});
}
@@ -2253,7 +2254,7 @@ const handleBackendChange = (e) => {
updatePrefs();
// restart wavesurfer regions to set new maxLength
initRegion();
- loadModel();
+ loadModel({clearCache: false});
}
const backend = document.getElementsByName('backend');
@@ -3472,7 +3473,7 @@ batchSizeSlider.addEventListener('input', (e) => {
})
batchSizeSlider.addEventListener('change', (e) => {
config[config.backend].batchSize = BATCH_SIZE_LIST[e.target.value];
- loadModel();
+ loadModel({clearCache: false});
updatePrefs();
// Reset region maxLength
initRegion();
@@ -3960,7 +3961,7 @@ ThreadSlider.addEventListener('input', () => {
});
ThreadSlider.addEventListener('change', () => {
config[config.backend].threads = ThreadSlider.valueAsNumber;
- loadModel();
+ loadModel({clearCache: false});
updatePrefs();
});
diff --git a/js/worker.js b/js/worker.js
index 7ac82179..89d5b4e4 100644
--- a/js/worker.js
+++ b/js/worker.js
@@ -204,7 +204,6 @@ const clearCache = async (fileCache, sizeLimitInGB) => {
const requiredSpace = sizeLimitInGB * 1024 ** 3;
// If Full, clear at least 25% of cache, so we're not doing this too frequently
if (size > requiredSpace) {
- // while (size > requiredSpace && canBeRemovedFromCache.length) {
while (canBeRemovedFromCache.length > 1) {
const file = canBeRemovedFromCache.shift();
const proxy = metadata[file].proxy;
@@ -251,9 +250,10 @@ break;
case "chart": {await onChartRequest(args);
break;
}
- case "clear-cache": {CACHE_LOCATION = p.join(TEMP, "chirpity");
-fs.existsSync(CACHE_LOCATION) || fs.mkdirSync(CACHE_LOCATION);
-await clearCache(CACHE_LOCATION, 0);
+ case "clear-cache": {
+ CACHE_LOCATION = p.join(TEMP, "chirpity");
+ fs.existsSync(CACHE_LOCATION) || fs.mkdirSync(CACHE_LOCATION);
+ await clearCache(CACHE_LOCATION, 0);
break;
}
case "convert-dataset": {convertSpecsFromExistingSpecs();
@@ -314,7 +314,12 @@ break;
event: "spawning"
});
sampleRate = args.model === "v2.4" ? 48_000 : 24_000;
-
+ // Since models have different sample rates, we need to clear the cache of
+ // files that have been resampled for a different model, and reset metadata
+ CACHE_LOCATION = p.join(TEMP, "chirpity");
+ DEBUG && console.log('clear cache', args.clearCache, 'location', CACHE_LOCATION)
+ args.clearCache && ipcRenderer.invoke('clear-cache', CACHE_LOCATION)
+ metadata = {}
BATCH_SIZE = parseInt(args.batchSize);
setAudioContext(sampleRate);
memoryDB = undefined;
diff --git a/main.js b/main.js
index d65192cd..428ca3a7 100644
--- a/main.js
+++ b/main.js
@@ -489,3 +489,9 @@ ipcMain.handle('saveFile', (event, arg) => {
});
mainWindow.webContents.send('saveFile', { message: 'file saved!' });
});
+
+ipcMain.handle('clear-cache', (event, filePath) => {
+ // console.log("cache location:", event, filePath);
+ // return
+ clearCache(filePath)
+})
\ No newline at end of file
diff --git a/package.json b/package.json
index 3d4d0d6c..f1752d89 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "chirpity",
- "version": "0.11.0",
+ "version": "0.11.1",
"description": "Chirpity Nocmig",
"main": "main.js",
"scripts": {
@@ -98,7 +98,7 @@
],
"mac": {
"target": {
- "target": "dmg",
+ "target": "pkg",
"arch": "arm64"
},
"files": [
@@ -186,6 +186,7 @@
"@easepick/bundle": "^1.2.1",
"@fast-csv/format": "^4.3.5",
"@popperjs/core": "^2.9.2",
+ "@tensorflow/tfjs-core": "^4.14.0",
"@tensorflow/tfjs-node": "^4.14.0",
"bootstrap": "5.2.2",
"browser-id3-writer": "^4.4.0",
diff --git a/preload.js b/preload.js
index 6bcc1e01..20b943da 100644
--- a/preload.js
+++ b/preload.js
@@ -51,7 +51,7 @@ contextBridge.exposeInMainWorld('electron', {
getPath: () => ipcRenderer.invoke('getPath'),
getTemp: () => ipcRenderer.invoke('getTemp'),
getVersion: () => ipcRenderer.invoke('getVersion'),
- getAudio: () => ipcRenderer.invoke('getAudio'),
+ getAudio: () => ipcRenderer.invoke('getAudio')
});
contextBridge.exposeInMainWorld('module', {