Skip to content
This repository has been archived by the owner on Dec 1, 2023. It is now read-only.

Commit

Permalink
Merge remote-tracking branch 'upstream/main' into main
Browse files Browse the repository at this point in the history
  • Loading branch information
petebankhead committed Sep 2, 2021
2 parents bdbcad8 + 3ee24cd commit 704904b
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 20 deletions.
36 changes: 34 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,17 @@ and remains in a not-quite-complete state.
Its previous main use was to run [StarDist](https://qupath.readthedocs.io/en/0.2/docs/advanced/stardist.html)
nucleus identification, although the new [QuPath StarDist extension](https://github.com/qupath/qupath-extension-stardist) does not require that TensorFlow is available.

> **Important!** TensorFlow Java does not currently support Mac computers with Apple silicon.

## Building

There is no pre-built version of the TensorFlow extension at this time, because most people shouldn't need it and there are lots of different permutations of dependencies that might be required for different platforms.

For that reason, it needs to be built from source.
If you want to match to a specific version, you can download the source from the [releases](https://github.com/qupath/qupath-extension-tensorflow/releases) page.


### Extension + dependencies separately

You can build the extension with
Expand All @@ -37,7 +45,7 @@ extension and all its dependencies with
gradlew clean shadowjar
```

### GPU support
### Alternative platforms

The default build process will use TensorFlow for the CPU.

Expand All @@ -48,11 +56,35 @@ To use any of these, add the platform to any of the building tasks above.
For example, to create a single GPU-friendly jar, use

```bash
gradlew clean shadowjar -P platform=gpu
gradlew clean build copyDependencies -P platform=gpu
```

The platforms available at the time of writing are `mkl`, `gpu`, `mkl-gpu`.

> Not all options are available for all operating systems.
> For example, GPU support is not available with macOS.

### GPU support

When using `platform=gpu`, you will need
* an NVIDIA GPU
* CUDA and cuDNN

Installation may be simplified if you include

```bash
gradlew clean build copyDependencies -P platform=gpu -Pcuda-redist
```

to download the required CUDA files via JavaCPP.

Before using this option, please check https://github.com/bytedeco/javacpp-presets/tree/master/cuda for
the terms of license agreements for NVIDIA software included in the archives.

> **Warning!** At the time of writing, the CUDA version used with TensorFlow Java differs from that
> used with OpenCV via JavaCPP. This is likely to cause problems if trying to use both.

## Installing

Expand Down
37 changes: 23 additions & 14 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -11,15 +11,15 @@ repositories {
// mavenLocal()

mavenCentral()

maven {
url "https://maven.scijava.org/content/repositories/releases"
}

maven {
url "https://maven.scijava.org/content/repositories/snapshots"
}

}

/*
Expand All @@ -37,44 +37,52 @@ description = 'QuPath extension to use TensorFlow'
version = "0.3.0"

dependencies {
def tensorflowVersion = "0.3.2"
def tensorflowVersion = "0.3.3"
def cudaVersion = "11.0-8.0-1.5.4" // Warning! This doesn't match version with QuPath v0.3.0 + opencv-platform-gpu
def qupathVersion = "0.3.0" // For now
def qupathVersion = "0.3.0"

def platform = project.findProperty("platform")

if (platform) {
implementation "org.tensorflow:tensorflow-core-platform-${platform}:${tensorflowVersion}"
} else {
implementation "org.tensorflow:tensorflow-core-platform:${tensorflowVersion}"
}

if (useCuda) {
implementation "org.bytedeco:cuda-platform:${cudaVersion}"
if (useCudaRedist) {
implementation "org.bytedeco:cuda-platform-redist:${cudaVersion}"
}
}

shadow "io.github.qupath:qupath-gui-fx:${qupathVersion}"
shadow "org.slf4j:slf4j-api:1.7.30"

testImplementation "io.github.qupath:qupath-gui-fx:${qupathVersion}"
testImplementation "org.junit.jupiter:junit-jupiter-api:5.7.2"
testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine'

}

processResources {
from ("${projectDir}/LICENSE.txt") {
into 'licenses/'
}

doLast {
if (useCuda) {
logger.quiet("Requesting CUDA support - by downloading these archives you agree to the terms of the license " +
" agreements for NVIDIA software included in the archives.")
logger.quiet("See https://github.com/bytedeco/javacpp-presets/tree/master/cuda for more information.")
}
}
}

tasks.register("copyDependencies", Copy) {
description "Copy dependencies into the build directory for use elsewhere"
group "QuPath"

from configurations.default
into 'build/libs'
}
Expand All @@ -90,6 +98,7 @@ java {
withSourcesJar()
if (project.properties['javadocs'])
withJavadocJar()

}

/*
Expand All @@ -102,7 +111,7 @@ if (!strictJavadoc) {
options.addStringOption('Xdoclint:none', '-quiet')
}
}

/*
* Avoid 'Entry .gitkeep is a duplicate but no duplicate handling strategy has been set.'
* when using withSourcesJar()
Expand All @@ -113,4 +122,4 @@ tasks.withType(org.gradle.jvm.tasks.Jar) {

tasks.named('test') {
useJUnitPlatform()
}
}
9 changes: 5 additions & 4 deletions src/main/java/qupath/ext/tensorflow/TensorFlowBundle.java
Original file line number Diff line number Diff line change
Expand Up @@ -74,8 +74,8 @@ private TensorFlowBundle(String pathModel) {
if (inputs == null || inputs.isEmpty()) {
logger.info("Found SignatureDef: {} (method={})", entry.getKey(), sigdef.getMethodName());
signatureDefKey = entry.getKey();
inputs = sigdef.getInputsMap().values().stream().map(t -> new SimpleTensorInfo(t)).collect(Collectors.toList());
outputs = sigdef.getOutputsMap().values().stream().map(t -> new SimpleTensorInfo(t)).collect(Collectors.toList());
inputs = sigdef.getInputsMap().entrySet().stream().map(e -> new SimpleTensorInfo(e.getKey(), e.getValue())).collect(Collectors.toList());
outputs = sigdef.getOutputsMap().entrySet().stream().map(e -> new SimpleTensorInfo(e.getKey(), e.getValue())).collect(Collectors.toList());
} else {
logger.warn("Extra SignatureDef found - will be ignored ({}, method={})", entry.getKey(), sigdef.getMethodName());
}
Expand All @@ -95,6 +95,7 @@ private TensorFlowBundle(String pathModel) {
private static Map<String, TensorFlowBundle> cachedBundles = new HashMap<>();

static TensorFlowBundle loadBundle(String path) {
cachedBundles.clear();
return cachedBundles.computeIfAbsent(path, p -> new TensorFlowBundle(p));
}

Expand Down Expand Up @@ -198,9 +199,9 @@ public static class SimpleTensorInfo {
private String name;
private long[] shape;

SimpleTensorInfo(TensorInfo info) {
SimpleTensorInfo(String name, TensorInfo info) {
this.info = info;
this.name = info.getName();
this.name = name;
if (info.hasTensorShape()) {
var dims = info.getTensorShape().getDimList();
shape = new long[dims.size()];
Expand Down
5 changes: 5 additions & 0 deletions src/main/java/qupath/ext/tensorflow/TensorFlowExtension.java
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import qupath.lib.common.Version;
import qupath.lib.gui.QuPathGUI;
import qupath.lib.gui.extensions.GitHubProject;
import qupath.lib.gui.extensions.QuPathExtension;
Expand Down Expand Up @@ -61,6 +62,10 @@ public GitHubRepo getRepository() {
return GitHubRepo.create(getName(), "qupath", "qupath-extension-tensorflow");
}

@Override
public Version getQuPathVersion() {
return Version.parse("0.3.0-rc2");
}


}

0 comments on commit 704904b

Please sign in to comment.