-
Notifications
You must be signed in to change notification settings - Fork 34
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update JHDF5 library to 19.04.0 #181
Comments
@ctrueden thanks a lot for announcing this! I also have a couple of repos that are using hdf5:
Sorry, I did not get exactly what I need to do? Update/add a dependency in the pom and then change the code accordingly? |
The summary is that as of HDF5 1.10, HDF5 Group now have the Java bindings (JHI5) in the main repository. JHDF5 now builds off those bindings. HDF5 Group Java HDF5 Interface (JHI5): Current JHDF5 javadocs and source from ETHZ SIS: Note that the The previous API contained in Edited to clarify |
This issue has been mentioned on Image.sc Forum. There might be relevant details there: https://forum.image.sc/t/hdf5-common-format-for-ilastik-bdv-and-imaris/57860/13 |
@tischi wrote:
The first thing to do would be to make sure you are depending on: <properties>
<cisd.jhdf5.version>19.04.0</cisd.jhdf5.version>
</properties>
<dependency>
<groupId>cisd</groupId>
<artifactId>jhdf5</artifactId>
<version>${cisd.jhdf5.version}</version>
</dependency> and not any other version of JHDF5. Once you've made that switch, you are likely to have compile errors around the no-longer-present |
Some experiences:
Here are the changes that I made to imaris-writer. |
Probably as expected I am not yet able to actually run the tests in Screenshot of the ping @tpietzsch |
CCing folks involved with a repository linked above: @axtimwalde @bogovicj @StephanPreibisch @maarzt @rejsmont @k-dominik @m-novikov @sbesson @dgault @joshmoore. We're trying to migrate the SciJava component collection to a newer HDF5 library. Help, comments, discussion, etc., very welcome. |
Thanks for starting the discussion @ctrueden. Several of us are currently on leave but we'll discuss this next week and get back to you. As a preliminary outcome, a naive bump of the
Looking briefly at the Javadoc and the source code links pasted by @mkitti above, it looks like this package is indeed no longer shipped as part of the library. Like above, this API might have been retired in favor of the equivalent API in the upstream Java bindings but I have not investigated further. |
The current source for that package is here: |
According to a classname search, it was embedded in cisd:jhdf5 through 14.12.6, and is no longer present in cisd:jhdf5:19.04.0, as @sbesson notes. That same search shows that cisd:base:18.09.0 also contains that package. And the POM of cisd:jhdf5:19.04.0 depends on it. What surprises me is that @sbesson's "naive bump" to cisd:jhdf5:19.04.0 would yield such compile errors, because cisd:base:18.09.0 should have been brought in also as a transitive dependency. |
@sbesson I tried updating the JHDF5 version in ome/bioformats as well, and everything builds fine. Here is the patch I used: diff --git a/components/formats-bsd/pom.xml b/components/formats-bsd/pom.xml
index f8be993e9b..7d10ac168f 100644
--- a/components/formats-bsd/pom.xml
+++ b/components/formats-bsd/pom.xml
@@ -73,6 +73,11 @@
<artifactId>kryo</artifactId>
<version>${kryo.version}</version>
</dependency>
+ <dependency>
+ <groupId>commons-lang</groupId>
+ <artifactId>commons-lang</artifactId>
+ <version>2.6</version>
+ </dependency>
<dependency>
<groupId>org.perf4j</groupId>
<artifactId>perf4j</artifactId>
@@ -100,7 +105,7 @@
<dependency>
<groupId>cisd</groupId>
<artifactId>jhdf5</artifactId>
- <version>14.12.6</version>
+ <version>19.04.0</version>
</dependency>
<dependency>
<groupId>com.drewnoakes</groupId> All the formats-bsd tests also still pass (though they take 90 seconds to run). The commons-lang dependency was being brought in transitively by the old jhdf5, but the new jhdf5 no longer depends on it... but it is an actual dependency of formats-bsd, so should be declared here regardless. So early signs point to formats-bsd not struggling too much with this update! 👍 |
Thanks @ctrueden, great to see that you managed to compile. The fact that Looking again, I think there is issue come from the Looking at the content of my local POM, which was downloaded from this cache rather than upstream Maven Scijava:
differs from the https://maven.scijava.org/content/groups/public/cisd/jhdf5/19.04.0/jhdf5-19.04.0.pom which declares the dependency. Comparing the timestamps of https://maven.scijava.org/content/groups/public/cisd/jhdf5/19.04.0/ and adds to my confusion. While most of the components were indeed replicated the next day, the POM and others seemed to have been uploaded on Sep 2020. |
👍
If I had to hazard a guess: perhaps when I first uploaded 19.04.0 I did it directly without a custom POM, then realized it would need to have cisd:base a dependency and deleted and reuploaded it, and your cache was generated during the intervening time. I do not specifically recall that happening, but it seems like the sort of thing I would do. If you are concerned about more general discrepancies beyond only these components, you could write a script to compare the md5sums across all of your cached components, just to be safe. |
Quick update on this front: the PR mentioned in #181 (reference) and bumping the |
Because jhdf5 is excluded here, I'm not sure if there is anything to do in multiview-reconstruction |
@mkitti yes same comment as fiji/register_virtual_stack_slices#13 (comment), I believe this exclusion is obsolete and can be safely removed. Thanks for driving this! |
@ctrueden which version property should we use? You mentioned in a snippet above
Should we just override the
construct? |
TL;DR: Either one should be fine! Overriding the short-name property will keep the two values aligned, though. Background: To avoid future name clashes, pom-scijava has switched over to fully qualified version properties for all version management. However, it also defines a short style property as well. For example: <ui-behaviour.version>2.0.5</ui-behaviour.version>
<org.scijava.ui-behaviour.version>${ui-behaviour.version}</org.scijava.ui-behaviour.version> And then the actual JHDF5 is no different; this is how it's set up in pom-scijava now. Caveat emptor: As far as overriding it in downstream POMs goes, it does not matter which one you use. But either way, it is important that all version property overrides in specific POMs be transient. Ideally, a component release should not contain any version property overrides, although I appreciate this this is not always possible. (If a release has a component override to a newer version than its associated BOM, then that newer version will NOT be brought in when depending on that component from another pom-scijava-inheriting project, unfortunately, because the dependency's properties are not inherited—properties only inherit from your parent POM.) |
@tischi BDV-core has now been updated: bigdataviewer/bigdataviewer-core#131 Perhaps your tests on |
Thanks, yes, using |
As of 2f7d665, the entire SciJava component collection is free of |
This issue has been mentioned on Image.sc Forum. There might be relevant details there: https://forum.image.sc/t/new-bigdataviewer-version-10-4-1/68818/4 |
This issue has been mentioned on Image.sc Forum. There might be relevant details there: https://forum.image.sc/t/length-is-too-large-error-in-imagej/62952/5 |
This issue has been mentioned on Image.sc Forum. There might be relevant details there: https://forum.image.sc/t/timeline-for-the-next-fiji-update/69640/3 |
See also fiji/HDF5_Vibez#18 |
Today I released pom-scijava 32.0.0, with a harmonious BOM across all JHDF5-related components. We are now on jhdf5 19.04.1. Any components above which are not managed by pom-scijava are on their own to follow suit. If you want to be part of the update process in future, you can file a PR adding version management of your components to pom-scijava, and your components will become part of the "mega-melt" BOM harmony testing. |
Right now we are managing the CISD JHDF5 library at 14.12.6. We would like to upgrade to 19.04.0, to take advantage of new capabilities in HDF5. However, there are two obstacles:
The
H5D
class was retired in favor of theH5
class from upstream HDF Group's HDF5 Java bindings. Usages ofH5D
in consumer libraries will need to be updated to theirH5
-based equivalents.The JHDF5 library has been deployed with two different groupIds,
cisd
andch.systems.cisd
, with the SciJava community later agreeing to unify aroundcisd
and stop using thech.systems.cisd
groupId (Reconcile jhdf5 artifact usages #87). But some components are still usingch.systems.cisd
; fortunately, updating them to 19.04.0 will naturally fix the groupId because we have not deployed 19.04.0 to maven.scijava.org under the oldch.systems.cisd
groupId. But we still need to be careful to upgrade everything across the board at once, and/or exclude the coordinate with old groupId from dependency trees in cases where it leaks in.Here is a table of which components on my radar use JHDF5 in its various incarnations:
ch.systems.cisd:jhdf5
cisd:jhdf5
org.scala-saddle:jhdf5_2.10
The checkboxes here can be checked when a particular component has migrated to JHDF5 19.04.0. And once all checkboxes are checked (except vcell-bioformats, which is probably out of scope here), this issue can be closed.
See also this and that and now also that chat thread.
CC @mkitti
The text was updated successfully, but these errors were encountered: