P.S. What you suggest can be used as adjacency graph, and synonyms can be 
found through good old Breath First Search on it to find a presence/absence 
of path between two words.

On Saturday, April 10, 2021 at 4:04:41 AM UTC+2 dsblak...@gmail.com wrote:

> In practice I would probably just build a map, word : #setofsynonyms and 
> whenever a synonym was added [a b], I would add b to a's set and a to b's 
> set.
>
> Or, even more likely, a vector, because "a" is probably a homonym (if 
> we're talking English) and if "a" is "bank", I need one set of synonyms for 
> "places to put your money" and another set for "the side of a river" and 
> another set for "to hit [an object] off a wall or other barrier". Unless 
> you have some other annotation besides the word so that you can distinguish 
> "bank[1]" from "bank[2]" and "bank[3]".
>
> On Fri, Apr 9, 2021 at 7:32 AM SideStep <nesvarb...@gmail.com> wrote:
>
>>
>> Task is to write a program that can decide whether two words are synonyms 
>> or not. 
>>
>> I have pairs of synonymous words, E.g.:
>>
>>  [big large]  
>>  [large huge]  
>>  [small little] 
>>
>> We can derive the synonymous relationship indirectly: if big is a synonym 
>> for large and large is a synonym for huge then big is a synonym for huge.
>> Being synonyms doesn’t depend on order, e.g. if big is a synonym for 
>> large then large is a synonym for big.
>>
>> The program has to answer whether given two words are synonyms or not.
>>
>> This seems to me as a good candidate for logic programming, e.g. with 
>> clojure.core.logic.
>>
>> a. How to state the input pairs of synonyms as logical 
>> statements/constraints?
>> b. How to perform a query to find all synonyms of a given word?
>>
>> Or perhaps I am yack shaving? What would be a simpler way to solve this?
>>
>> This question is also on stackowerflow, if you want to get some points:
>>
>>
>> https://stackoverflow.com/questions/67002758/logic-programming-find-synonyms-of-a-given-word
>>
>> -- 
>> You received this message because you are subscribed to the Google
>> Groups "Clojure" group.
>> To post to this group, send email to clo...@googlegroups.com
>> Note that posts from new members are moderated - please be patient with 
>> your first post.
>> To unsubscribe from this group, send email to
>> clojure+u...@googlegroups.com
>> For more options, visit this group at
>> http://groups.google.com/group/clojure?hl=en
>> --- 
>> You received this message because you are subscribed to the Google Groups 
>> "Clojure" group.
>> To unsubscribe from this group and stop receiving emails from it, send an 
>> email to clojure+u...@googlegroups.com.
>> To view this discussion on the web visit 
>> https://groups.google.com/d/msgid/clojure/0cd164b2-56eb-4e99-866d-b1f63522ac52n%40googlegroups.com
>>  
>> <https://groups.google.com/d/msgid/clojure/0cd164b2-56eb-4e99-866d-b1f63522ac52n%40googlegroups.com?utm_medium=email&utm_source=footer>
>> .
>>
>

-- 
You received this message because you are subscribed to the Google
Groups "Clojure" group.
To post to this group, send email to clojure@googlegroups.com
Note that posts from new members are moderated - please be patient with your 
first post.
To unsubscribe from this group, send email to
clojure+unsubscr...@googlegroups.com
For more options, visit this group at
http://groups.google.com/group/clojure?hl=en
--- 
You received this message because you are subscribed to the Google Groups 
"Clojure" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to clojure+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/clojure/56b72599-df75-43ce-a83d-b434fe4f0dfen%40googlegroups.com.

Reply via email to