基于 WordNet 的语义相似度 (WNetSS) API

WordNet-based Semantic Similarity (WNetSS) API

我正在使用 WNetSS API in my research to calculate semantic similarity between words. I followed their instructions listed in this page. I run the first example and it worked perfectly and the database has loaded successfully, but when I tried to run the second example,显示了这个错误:

run:
The database WordnetSemanticSimilarity is created.
Feb 13, 2018 11:34:07 PM net.sf.extjwnl.dictionary.Dictionary setInstance
INFO: Installing dictionary net.sf.extjwnl.dictionary.FileBackedDictionary@e73f9ac
Loading WordNet2.1 in progress ...
Exception in thread "main" com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate entry '1740-noun' for key 'PRIMARY'
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)
    at com.mysql.jdbc.Util.getInstance(Util.java:386)
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1040)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4074)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4006)
    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2468)
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2629)
    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2719)
    at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2155)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2450)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2371)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2355)
    at WordNetSemanticSimilarity.WordNetTreatment.WordNetProcessing.LoadWordNetInDataBase(WordNetProcessing.java:259)
    at wnetssexamples.Example0.main(Example0.java:39)
C:\Users\Administrator\AppData\Local\NetBeans\Cache.2\executor-snippets\run.xml:53: Java returned: 1
BUILD FAILED (total time: 1 second)

我尝试打开第一个示例中创建的数据库,发现有四行具有相同的键值,但不确定这是否会改变 api:[=15 的逻辑=]

当我进一步尝试查找其中有多少重复行时 table 我发现了一个巨大的数字,如下图所示:

拜托,我不确定如何解决这个问题,因为我没有自己创建数据库,我只是在加载它。不知道这是作者的错还是我做错了什么。你的快速反应会很有帮助。

谢谢

这是因为你运行输入了 example 0 两次,这将重复数据集中的记录,应该做的是 运行 example 0 ,然后 example 1 运行 它四次每个更改以下行:

第一次POS pos=POS.ADVERB; 第二次POS pos=POS.ADJECTIVE; 第三次POS pos=POS.NOUN; 第四次POS pos=POS.VERB;

然后 运行 示例 6 四次,并在示例 1 中进行相同的修改。

然后尝试评论这些 类 并且永远不要再 运行 它们这样数据库和表就不会被覆盖。