ActivityPub Viewer

A small tool to view real-world ActivityPub objects as JSON! Enter a URL or username from Mastodon or a similar service below, and we'll send a request with the right Accept header to the server to view the underlying object.

Open in browser →
{ "@context": [ "https://www.w3.org/ns/activitystreams", { "ostatus": "http://ostatus.org#", "atomUri": "ostatus:atomUri", "inReplyToAtomUri": "ostatus:inReplyToAtomUri", "conversation": "ostatus:conversation", "sensitive": "as:sensitive", "toot": "http://joinmastodon.org/ns#", "votersCount": "toot:votersCount", "Hashtag": "as:Hashtag" } ], "id": "https://discuss.systems/users/ocratato/outbox?min_id=0&page=true", "type": "OrderedCollectionPage", "next": "https://discuss.systems/users/ocratato/outbox?max_id=112974504089977858&page=true", "prev": "https://discuss.systems/users/ocratato/outbox?min_id=113056660484013407&page=true", "partOf": "https://discuss.systems/users/ocratato/outbox", "orderedItems": [ { "id": "https://discuss.systems/users/ocratato/statuses/113056660484013407/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-31T12:35:34Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://mastodon.social/users/raiderrobert" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113056660484013407", "type": "Note", "summary": null, "inReplyTo": "https://mastodon.social/users/raiderrobert/statuses/113056524652013095", "published": "2024-08-31T12:35:34Z", "url": "https://discuss.systems/@ocratato/113056660484013407", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://mastodon.social/users/raiderrobert" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113056660484013407", "inReplyToAtomUri": "https://mastodon.social/users/raiderrobert/statuses/113056524652013095", "conversation": "tag:mastodon.social,2024-08-31:objectId=788295049:objectType=Conversation", "content": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://mastodon.social/@raiderrobert\" class=\"u-url mention\">@<span>raiderrobert</span></a></span> <br />I was procrastinating, but I have put it off until later.</p>", "contentMap": { "en": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://mastodon.social/@raiderrobert\" class=\"u-url mention\">@<span>raiderrobert</span></a></span> <br />I was procrastinating, but I have put it off until later.</p>" }, "attachment": [], "tag": [ { "type": "Mention", "href": "https://mastodon.social/users/raiderrobert", "name": "@raiderrobert@mastodon.social" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113056660484013407/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113056660484013407/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113056660484013407/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113056660484013407/likes", "type": "Collection", "totalItems": 1 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113056660484013407/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113055434211570039/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-31T07:23:43Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://hachyderm.io/users/nick_tune", "https://mathstodon.xyz/users/xinyao" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113055434211570039", "type": "Note", "summary": null, "inReplyTo": "https://hachyderm.io/users/nick_tune/statuses/113055257000026269", "published": "2024-08-31T07:23:43Z", "url": "https://discuss.systems/@ocratato/113055434211570039", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://hachyderm.io/users/nick_tune", "https://mathstodon.xyz/users/xinyao" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113055434211570039", "inReplyToAtomUri": "https://hachyderm.io/users/nick_tune/statuses/113055257000026269", "conversation": "tag:hachyderm.io,2024-08-30:objectId=185758752:objectType=Conversation", "content": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://hachyderm.io/@nick_tune\" class=\"u-url mention\">@<span>nick_tune</span></a></span> <span class=\"h-card\" translate=\"no\"><a href=\"https://mathstodon.xyz/@xinyao\" class=\"u-url mention\">@<span>xinyao</span></a></span> </p><p>You seem to be conflating the roles with the people. Who performs what role is obviously dependent on the organisation. </p><p>The important point is that someone WILL perform those roles, even if it is implicit, unintentional or accidental!</p><p>I would be disappointed if a PM in an IT organisation was unable to prepare a business case for the architectural role.</p>", "contentMap": { "en": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://hachyderm.io/@nick_tune\" class=\"u-url mention\">@<span>nick_tune</span></a></span> <span class=\"h-card\" translate=\"no\"><a href=\"https://mathstodon.xyz/@xinyao\" class=\"u-url mention\">@<span>xinyao</span></a></span> </p><p>You seem to be conflating the roles with the people. Who performs what role is obviously dependent on the organisation. </p><p>The important point is that someone WILL perform those roles, even if it is implicit, unintentional or accidental!</p><p>I would be disappointed if a PM in an IT organisation was unable to prepare a business case for the architectural role.</p>" }, "attachment": [], "tag": [ { "type": "Mention", "href": "https://hachyderm.io/users/nick_tune", "name": "@nick_tune@hachyderm.io" }, { "type": "Mention", "href": "https://mathstodon.xyz/users/xinyao", "name": "@xinyao@mathstodon.xyz" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113055434211570039/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113055434211570039/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113055434211570039/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113055434211570039/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113055434211570039/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113054940538449385/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-31T05:18:10Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://hachyderm.io/users/nick_tune", "https://mathstodon.xyz/users/xinyao" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113054940538449385", "type": "Note", "summary": null, "inReplyTo": "https://hachyderm.io/users/nick_tune/statuses/113052679325459675", "published": "2024-08-31T05:18:10Z", "url": "https://discuss.systems/@ocratato/113054940538449385", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://hachyderm.io/users/nick_tune", "https://mathstodon.xyz/users/xinyao" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113054940538449385", "inReplyToAtomUri": "https://hachyderm.io/users/nick_tune/statuses/113052679325459675", "conversation": "tag:hachyderm.io,2024-08-30:objectId=185758752:objectType=Conversation", "content": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://hachyderm.io/@nick_tune\" class=\"u-url mention\">@<span>nick_tune</span></a></span> <span class=\"h-card\" translate=\"no\"><a href=\"https://mathstodon.xyz/@xinyao\" class=\"u-url mention\">@<span>xinyao</span></a></span> <br />I would put much of those tasks in the project manager&#39;s basket.</p><p>Obviously the PM and architect need to work closely. The architect should provide a set of alternative implementation schedules for a range of resource vs development time trade-offs. Then its up to the PM to provide the resources and manage the process.</p><p>It gets more interesting if the architectural design, and hence the quality of the result, are involved in the trade-off calculations. It is still the PM&#39;s task to make those choices (typically with input from the CIO and board).</p>", "contentMap": { "en": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://hachyderm.io/@nick_tune\" class=\"u-url mention\">@<span>nick_tune</span></a></span> <span class=\"h-card\" translate=\"no\"><a href=\"https://mathstodon.xyz/@xinyao\" class=\"u-url mention\">@<span>xinyao</span></a></span> <br />I would put much of those tasks in the project manager&#39;s basket.</p><p>Obviously the PM and architect need to work closely. The architect should provide a set of alternative implementation schedules for a range of resource vs development time trade-offs. Then its up to the PM to provide the resources and manage the process.</p><p>It gets more interesting if the architectural design, and hence the quality of the result, are involved in the trade-off calculations. It is still the PM&#39;s task to make those choices (typically with input from the CIO and board).</p>" }, "attachment": [], "tag": [ { "type": "Mention", "href": "https://hachyderm.io/users/nick_tune", "name": "@nick_tune@hachyderm.io" }, { "type": "Mention", "href": "https://mathstodon.xyz/users/xinyao", "name": "@xinyao@mathstodon.xyz" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113054940538449385/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113054940538449385/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113054940538449385/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113054940538449385/likes", "type": "Collection", "totalItems": 1 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113054940538449385/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113054541882312637/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-31T03:36:47Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://discuss.systems/users/xand" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113054541882312637", "type": "Note", "summary": null, "inReplyTo": "https://discuss.systems/users/xand/statuses/113050713082776202", "published": "2024-08-31T03:36:47Z", "url": "https://discuss.systems/@ocratato/113054541882312637", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://discuss.systems/users/xand" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113054541882312637", "inReplyToAtomUri": "https://discuss.systems/users/xand/statuses/113050713082776202", "conversation": "tag:discuss.systems,2024-08-29:objectId=24241097:objectType=Conversation", "content": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://discuss.systems/@xand\" class=\"u-url mention\">@<span>xand</span></a></span> I would agree that putting ALL the type definitions into one module would be a mistake.<br />However, types that appear in interfaces might be best defined centrally.<br />The form of that definition depends on the coupling between modules. It could be in the implementation language, an interface defn. language, or something like XML or JSON.</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a></p>", "contentMap": { "en": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://discuss.systems/@xand\" class=\"u-url mention\">@<span>xand</span></a></span> I would agree that putting ALL the type definitions into one module would be a mistake.<br />However, types that appear in interfaces might be best defined centrally.<br />The form of that definition depends on the coupling between modules. It could be in the implementation language, an interface defn. language, or something like XML or JSON.</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a></p>" }, "attachment": [], "tag": [ { "type": "Mention", "href": "https://discuss.systems/users/xand", "name": "@xand" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/softwarearchitecture", "name": "#softwarearchitecture" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113054541882312637/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113054541882312637/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113054541882312637/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113054541882312637/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113054541882312637/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113049108246803257/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-30T04:34:56Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://discuss.systems/users/xand" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113049108246803257", "type": "Note", "summary": null, "inReplyTo": "https://discuss.systems/users/xand/statuses/113045981162046973", "published": "2024-08-30T04:34:56Z", "url": "https://discuss.systems/@ocratato/113049108246803257", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://discuss.systems/users/xand" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113049108246803257", "inReplyToAtomUri": "https://discuss.systems/users/xand/statuses/113045981162046973", "conversation": "tag:discuss.systems,2024-08-29:objectId=24241097:objectType=Conversation", "content": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://discuss.systems/@xand\" class=\"u-url mention\">@<span>xand</span></a></span> I think I prefer the term &quot;sub-projects&quot;.</p><p>Large projects are rarely successful, so they need to be subdivided. However this can introduce even more complexity if the sub-projects are interdependent.</p><p>My hypothesis is that the architect should define the interfaces between the modules and they should be implemented as a set of test harnesses prior to beginning main development.</p><p><a href=\"https://discuss.systems/tags/Softwarearchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>Softwarearchitecture</span></a></p>", "contentMap": { "en": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://discuss.systems/@xand\" class=\"u-url mention\">@<span>xand</span></a></span> I think I prefer the term &quot;sub-projects&quot;.</p><p>Large projects are rarely successful, so they need to be subdivided. However this can introduce even more complexity if the sub-projects are interdependent.</p><p>My hypothesis is that the architect should define the interfaces between the modules and they should be implemented as a set of test harnesses prior to beginning main development.</p><p><a href=\"https://discuss.systems/tags/Softwarearchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>Softwarearchitecture</span></a></p>" }, "attachment": [], "tag": [ { "type": "Mention", "href": "https://discuss.systems/users/xand", "name": "@xand" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/softwarearchitecture", "name": "#softwarearchitecture" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113049108246803257/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113049108246803257/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113049108246803257/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113049108246803257/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113049108246803257/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113045733452478154/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-29T14:16:41Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://discuss.systems/users/xand" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113045733452478154", "type": "Note", "summary": null, "inReplyTo": "https://discuss.systems/users/xand/statuses/113045471097788733", "published": "2024-08-29T14:16:41Z", "url": "https://discuss.systems/@ocratato/113045733452478154", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://discuss.systems/users/xand" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113045733452478154", "inReplyToAtomUri": "https://discuss.systems/users/xand/statuses/113045471097788733", "conversation": "tag:discuss.systems,2024-08-29:objectId=24241097:objectType=Conversation", "content": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://discuss.systems/@xand\" class=\"u-url mention\">@<span>xand</span></a></span> A modules module can be useful. I have a project that I used to experiment with independently developed modules. This relies on well defined interfaces. The modules module provided stub versions of all the modules so that the other modules could build test harnesses.</p><p><a href=\"https://sourceforge.net/projects/ocratato-vici/\" target=\"_blank\" rel=\"nofollow noopener noreferrer\" translate=\"no\"><span class=\"invisible\">https://</span><span class=\"ellipsis\">sourceforge.net/projects/ocrat</span><span class=\"invisible\">ato-vici/</span></a></p>", "contentMap": { "en": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://discuss.systems/@xand\" class=\"u-url mention\">@<span>xand</span></a></span> A modules module can be useful. I have a project that I used to experiment with independently developed modules. This relies on well defined interfaces. The modules module provided stub versions of all the modules so that the other modules could build test harnesses.</p><p><a href=\"https://sourceforge.net/projects/ocratato-vici/\" target=\"_blank\" rel=\"nofollow noopener noreferrer\" translate=\"no\"><span class=\"invisible\">https://</span><span class=\"ellipsis\">sourceforge.net/projects/ocrat</span><span class=\"invisible\">ato-vici/</span></a></p>" }, "attachment": [], "tag": [ { "type": "Mention", "href": "https://discuss.systems/users/xand", "name": "@xand" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113045733452478154/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113045733452478154/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113045733452478154/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113045733452478154/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113045733452478154/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113032611664022816/activity", "type": "Announce", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-27T06:39:38Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://noc.social/users/todayilearned", "https://discuss.systems/users/ocratato/followers" ], "object": "https://noc.social/users/todayilearned/statuses/113032066723805563" }, { "id": "https://discuss.systems/users/ocratato/statuses/113028591740064828/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-26T13:37:19Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://discuss.systems/users/djmoch" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113028591740064828", "type": "Note", "summary": null, "inReplyTo": "https://discuss.systems/users/djmoch/statuses/113028370324038168", "published": "2024-08-26T13:37:19Z", "url": "https://discuss.systems/@ocratato/113028591740064828", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://discuss.systems/users/djmoch" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113028591740064828", "inReplyToAtomUri": "https://discuss.systems/users/djmoch/statuses/113028370324038168", "conversation": "tag:discuss.systems,2024-08-26:objectId=24108983:objectType=Conversation", "content": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://discuss.systems/@djmoch\" class=\"u-url mention\">@<span>djmoch</span></a></span> I recall evenings spent hand setting the bits in an EPROM for a National Semiconductor SC/MP processor. Tedious doesn&#39;t begin to describe it.</p>", "contentMap": { "en": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://discuss.systems/@djmoch\" class=\"u-url mention\">@<span>djmoch</span></a></span> I recall evenings spent hand setting the bits in an EPROM for a National Semiconductor SC/MP processor. Tedious doesn&#39;t begin to describe it.</p>" }, "attachment": [], "tag": [ { "type": "Mention", "href": "https://discuss.systems/users/djmoch", "name": "@djmoch" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113028591740064828/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113028591740064828/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113028591740064828/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113028591740064828/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113028591740064828/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113021426286139112/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-25T07:15:03Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113021426286139112", "type": "Note", "summary": null, "inReplyTo": "https://discuss.systems/users/ocratato/statuses/113014243923520803", "published": "2024-08-25T07:15:03Z", "url": "https://discuss.systems/@ocratato/113021426286139112", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113021426286139112", "inReplyToAtomUri": "https://discuss.systems/users/ocratato/statuses/113014243923520803", "conversation": "tag:discuss.systems,2024-08-22:objectId=23927070:objectType=Conversation", "content": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>This project is going to be very much exploratory programming. I have no idea if this is going to work. It will be fun.</p><p>The program will need something to chew on. I think &quot;example data&quot; would be a better term than &quot;test data&quot;. Testing is the process of confirming a program coforms to its design. At this stage we have no design.</p><p>I have chosen five paragraphs from various design documents. They include a paragraph from a preliminary design, a functional requirement, a use case, an architectural tactic and a component description.</p><p>The input to the process is an RDF model that represents the information in the paragraph. This is intended to simulate an extract from what will be in SASSY&#39;s knowledge database. </p><p>I am currently constucting these models.</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a><br /><a href=\"https://discuss.systems/tags/NLG\" class=\"mention hashtag\" rel=\"tag\">#<span>NLG</span></a> <a href=\"https://discuss.systems/tags/NaturalLanguageGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>NaturalLanguageGeneration</span></a></p>", "contentMap": { "en": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>This project is going to be very much exploratory programming. I have no idea if this is going to work. It will be fun.</p><p>The program will need something to chew on. I think &quot;example data&quot; would be a better term than &quot;test data&quot;. Testing is the process of confirming a program coforms to its design. At this stage we have no design.</p><p>I have chosen five paragraphs from various design documents. They include a paragraph from a preliminary design, a functional requirement, a use case, an architectural tactic and a component description.</p><p>The input to the process is an RDF model that represents the information in the paragraph. This is intended to simulate an extract from what will be in SASSY&#39;s knowledge database. </p><p>I am currently constucting these models.</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a><br /><a href=\"https://discuss.systems/tags/NLG\" class=\"mention hashtag\" rel=\"tag\">#<span>NLG</span></a> <a href=\"https://discuss.systems/tags/NaturalLanguageGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>NaturalLanguageGeneration</span></a></p>" }, "attachment": [], "tag": [ { "type": "Hashtag", "href": "https://discuss.systems/tags/sassy", "name": "#sassy" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/softwarearchitecture", "name": "#softwarearchitecture" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/nlg", "name": "#nlg" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/naturallanguagegeneration", "name": "#naturallanguagegeneration" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113021426286139112/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113021426286139112/replies?min_id=113197177982819810&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113021426286139112/replies", "items": [ "https://discuss.systems/users/ocratato/statuses/113197177982819810" ] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113021426286139112/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113021426286139112/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113014243923520803/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-24T00:48:29Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113014243923520803", "type": "Note", "summary": null, "inReplyTo": "https://discuss.systems/users/ocratato/statuses/113009084793506870", "published": "2024-08-24T00:48:29Z", "url": "https://discuss.systems/@ocratato/113014243923520803", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113014243923520803", "inReplyToAtomUri": "https://discuss.systems/users/ocratato/statuses/113009084793506870", "conversation": "tag:discuss.systems,2024-08-22:objectId=23927070:objectType=Conversation", "content": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>There is one classification of the RST reationships that we can use. They can be either structural or semantic. The structural relationships will come from the overall design of the document. The semantic ones come from the data properties - i.e. the predicates of the RDF statements.</p><p>In practice this means that the sorted order for the RDF statements within a paragraph is based on the semantics.</p><p>This SASSY subproject aims to take lists of RDF statements and sort each list based on the semantic ranks. The RDF statements will then be agregated into sentence sized chunks. </p><p>The next step is the internal organisation of the sentences, such as adjectival phrases and subordinate clauses. </p><p>An interesting step is to identify the flow of focus and use that to replace nouns (Fred) with pronouns (he) or noun phrases (the boy). For a design document it is especially important not to introduce any ambiguity.</p><p>The final step is to create a grammar tree for each sentence and pass it to the NLG program.</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a><br /><a href=\"https://discuss.systems/tags/NLG\" class=\"mention hashtag\" rel=\"tag\">#<span>NLG</span></a> <a href=\"https://discuss.systems/tags/NaturalLanguageGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>NaturalLanguageGeneration</span></a></p>", "contentMap": { "en": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>There is one classification of the RST reationships that we can use. They can be either structural or semantic. The structural relationships will come from the overall design of the document. The semantic ones come from the data properties - i.e. the predicates of the RDF statements.</p><p>In practice this means that the sorted order for the RDF statements within a paragraph is based on the semantics.</p><p>This SASSY subproject aims to take lists of RDF statements and sort each list based on the semantic ranks. The RDF statements will then be agregated into sentence sized chunks. </p><p>The next step is the internal organisation of the sentences, such as adjectival phrases and subordinate clauses. </p><p>An interesting step is to identify the flow of focus and use that to replace nouns (Fred) with pronouns (he) or noun phrases (the boy). For a design document it is especially important not to introduce any ambiguity.</p><p>The final step is to create a grammar tree for each sentence and pass it to the NLG program.</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a><br /><a href=\"https://discuss.systems/tags/NLG\" class=\"mention hashtag\" rel=\"tag\">#<span>NLG</span></a> <a href=\"https://discuss.systems/tags/NaturalLanguageGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>NaturalLanguageGeneration</span></a></p>" }, "attachment": [], "tag": [ { "type": "Hashtag", "href": "https://discuss.systems/tags/sassy", "name": "#sassy" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/softwarearchitecture", "name": "#softwarearchitecture" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/nlg", "name": "#nlg" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/naturallanguagegeneration", "name": "#naturallanguagegeneration" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113014243923520803/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113014243923520803/replies?min_id=113021426286139112&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113014243923520803/replies", "items": [ "https://discuss.systems/users/ocratato/statuses/113021426286139112" ] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113014243923520803/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113014243923520803/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113009084793506870/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-23T02:56:27Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113009084793506870", "type": "Note", "summary": null, "inReplyTo": "https://discuss.systems/users/ocratato/statuses/113002817194682026", "published": "2024-08-23T02:56:27Z", "url": "https://discuss.systems/@ocratato/113009084793506870", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113009084793506870", "inReplyToAtomUri": "https://discuss.systems/users/ocratato/statuses/113002817194682026", "conversation": "tag:discuss.systems,2024-08-22:objectId=23927070:objectType=Conversation", "content": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>The core observation of Rhetorical Structure Theory (RST) is that text can be recursively subdivided into two parts, termed the &quot;nucleus&quot; and the &quot;satellite&quot;. The nucleus can be understood by itself, whereas the satellite depends on the nucleus.</p><p>RST researchers spent a lot of time trying to classify the relationships between the nucleus and satellite. Not much agreement was reached.</p><p>Their approach to text generation was to select a communicative goal which would indicate a general plan. The plan would suggest relationships and the database would then be searched for matching data.</p><p>For SASSY the communicative goal is simply &quot;tell us everything you know&quot;. The planning then collapses to a sorting process.</p><p>While playing around with ways to sort the data it became apparent that the actual set of RST relationships was not the important aspect. What was driving the algorithm was the ranking of the relationships. This is why the researchers could never agree on what relationships should be used - it doesn&#39;t matter.</p><p>For an RDF knowledge database I think this means that I just need to assign a &quot;semantic rank&quot; to each property. We shall see ...</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a><br /><a href=\"https://discuss.systems/tags/NLG\" class=\"mention hashtag\" rel=\"tag\">#<span>NLG</span></a> <a href=\"https://discuss.systems/tags/NaturalLanguageGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>NaturalLanguageGeneration</span></a></p>", "contentMap": { "en": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>The core observation of Rhetorical Structure Theory (RST) is that text can be recursively subdivided into two parts, termed the &quot;nucleus&quot; and the &quot;satellite&quot;. The nucleus can be understood by itself, whereas the satellite depends on the nucleus.</p><p>RST researchers spent a lot of time trying to classify the relationships between the nucleus and satellite. Not much agreement was reached.</p><p>Their approach to text generation was to select a communicative goal which would indicate a general plan. The plan would suggest relationships and the database would then be searched for matching data.</p><p>For SASSY the communicative goal is simply &quot;tell us everything you know&quot;. The planning then collapses to a sorting process.</p><p>While playing around with ways to sort the data it became apparent that the actual set of RST relationships was not the important aspect. What was driving the algorithm was the ranking of the relationships. This is why the researchers could never agree on what relationships should be used - it doesn&#39;t matter.</p><p>For an RDF knowledge database I think this means that I just need to assign a &quot;semantic rank&quot; to each property. We shall see ...</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a><br /><a href=\"https://discuss.systems/tags/NLG\" class=\"mention hashtag\" rel=\"tag\">#<span>NLG</span></a> <a href=\"https://discuss.systems/tags/NaturalLanguageGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>NaturalLanguageGeneration</span></a></p>" }, "attachment": [], "tag": [ { "type": "Hashtag", "href": "https://discuss.systems/tags/sassy", "name": "#sassy" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/softwarearchitecture", "name": "#softwarearchitecture" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/nlg", "name": "#nlg" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/naturallanguagegeneration", "name": "#naturallanguagegeneration" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113009084793506870/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113009084793506870/replies?min_id=113014243923520803&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113009084793506870/replies", "items": [ "https://discuss.systems/users/ocratato/statuses/113014243923520803" ] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113009084793506870/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113009084793506870/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113003439068516285/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-22T03:00:40Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://hachyderm.io/users/nick_tune" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113003439068516285", "type": "Note", "summary": null, "inReplyTo": "https://hachyderm.io/users/nick_tune/statuses/113001511259673124", "published": "2024-08-22T03:00:40Z", "url": "https://discuss.systems/@ocratato/113003439068516285", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://hachyderm.io/users/nick_tune" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113003439068516285", "inReplyToAtomUri": "https://hachyderm.io/users/nick_tune/statuses/113001511259673124", "conversation": "tag:hachyderm.io,2024-08-21:objectId=183039564:objectType=Conversation", "content": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://hachyderm.io/@nick_tune\" class=\"u-url mention\">@<span>nick_tune</span></a></span> Yes. If the granularity is too small you will either spend all your time fetching and storing state data, or have complex state management in each event handler.</p><p>I developed a small Actor &amp; Message library for C++. I gave up on it when it became obvious that the overall process algorithm would become lost in a tangle of event handlers.</p><p>I foresee the same problem no matter the granularity for an event driven system.</p>", "contentMap": { "en": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://hachyderm.io/@nick_tune\" class=\"u-url mention\">@<span>nick_tune</span></a></span> Yes. If the granularity is too small you will either spend all your time fetching and storing state data, or have complex state management in each event handler.</p><p>I developed a small Actor &amp; Message library for C++. I gave up on it when it became obvious that the overall process algorithm would become lost in a tangle of event handlers.</p><p>I foresee the same problem no matter the granularity for an event driven system.</p>" }, "attachment": [], "tag": [ { "type": "Mention", "href": "https://hachyderm.io/users/nick_tune", "name": "@nick_tune@hachyderm.io" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113003439068516285/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113003439068516285/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113003439068516285/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113003439068516285/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113003439068516285/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/113002817194682026/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-22T00:22:31Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/113002817194682026", "type": "Note", "summary": null, "inReplyTo": null, "published": "2024-08-22T00:22:31Z", "url": "https://discuss.systems/@ocratato/113002817194682026", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/113002817194682026", "inReplyToAtomUri": null, "conversation": "tag:discuss.systems,2024-08-22:objectId=23927070:objectType=Conversation", "content": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>Natural Language Generation has gone through three major phases. Initially templates were used. This evolved into Rhetorical Structure Theory which tried to use planning to deduce the structure of the text. More recently Large Language Models have got the attention of the NLG community.</p><p>Templates do not have the flexibility to handle arbitrary software designs. Any novel attribute of a design would likely be overlooked by the templates.</p><p>LLMs appear to be non-deterministic. This is a problem for design documents. They need to be able to be regenerated at any time and the only changes should be a direct result of changes in the data.</p><p>A lot of work was done on RST in the 80&#39;s and 90&#39;s. The fact that there is not any readily available RST based software available today is a good clue that it was not a successful endevour. </p><p>I found two major issues with RST: Firstly the planning approach could leave important information unreported. This is a show stopper for SASSY. Secondly, in order to get good results it took months long collaboration between linguists and subject matter experts. This would also be an obsticle for SASSY that aims to be an easy to use tool for helping with software design.</p><p>Next I will discuss my plan to adapt RST for use in SASSY.</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a><br /><a href=\"https://discuss.systems/tags/NLG\" class=\"mention hashtag\" rel=\"tag\">#<span>NLG</span></a> <a href=\"https://discuss.systems/tags/NaturalLanguageGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>NaturalLanguageGeneration</span></a></p>", "contentMap": { "en": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>Natural Language Generation has gone through three major phases. Initially templates were used. This evolved into Rhetorical Structure Theory which tried to use planning to deduce the structure of the text. More recently Large Language Models have got the attention of the NLG community.</p><p>Templates do not have the flexibility to handle arbitrary software designs. Any novel attribute of a design would likely be overlooked by the templates.</p><p>LLMs appear to be non-deterministic. This is a problem for design documents. They need to be able to be regenerated at any time and the only changes should be a direct result of changes in the data.</p><p>A lot of work was done on RST in the 80&#39;s and 90&#39;s. The fact that there is not any readily available RST based software available today is a good clue that it was not a successful endevour. </p><p>I found two major issues with RST: Firstly the planning approach could leave important information unreported. This is a show stopper for SASSY. Secondly, in order to get good results it took months long collaboration between linguists and subject matter experts. This would also be an obsticle for SASSY that aims to be an easy to use tool for helping with software design.</p><p>Next I will discuss my plan to adapt RST for use in SASSY.</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a><br /><a href=\"https://discuss.systems/tags/NLG\" class=\"mention hashtag\" rel=\"tag\">#<span>NLG</span></a> <a href=\"https://discuss.systems/tags/NaturalLanguageGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>NaturalLanguageGeneration</span></a></p>" }, "attachment": [], "tag": [ { "type": "Hashtag", "href": "https://discuss.systems/tags/sassy", "name": "#sassy" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/softwarearchitecture", "name": "#softwarearchitecture" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/nlg", "name": "#nlg" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/naturallanguagegeneration", "name": "#naturallanguagegeneration" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/113002817194682026/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/113002817194682026/replies?min_id=113009084793506870&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/113002817194682026/replies", "items": [ "https://discuss.systems/users/ocratato/statuses/113009084793506870" ] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/113002817194682026/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/113002817194682026/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/112997725845159703/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-21T02:47:43Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/112997725845159703", "type": "Note", "summary": null, "inReplyTo": "https://discuss.systems/users/ocratato/statuses/112993104764890632", "published": "2024-08-21T02:47:43Z", "url": "https://discuss.systems/@ocratato/112997725845159703", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/112997725845159703", "inReplyToAtomUri": "https://discuss.systems/users/ocratato/statuses/112993104764890632", "conversation": "tag:discuss.systems,2024-08-18:objectId=23759813:objectType=Conversation", "content": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>The next step in my feasibility study was to generate some English text. After examining some alternatives I selected SimpleNLG. A few tests convinced me that it would be a good basis.</p><p>However I was not happy with the way Java was being tortured. The main data structure was trees of lists of Java Objects - basically an unconstrained structure. A lot of the code consisted of tests of the type of Objects, which is an odd way to program a language which supports polymorphism. I did a rewrite in C++.</p><p>I added an RDF parser so that the input grammar tree can be supplied as an RDF Model. The result was able to complete the test cases provided for SimpleNLG.</p><p>This NLG is only able to create clauses and sentences so it will need to be wrapped in some other module to create the entire document. </p><p>This brings the story up to the present.</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a><br /><a href=\"https://discuss.systems/tags/NLG\" class=\"mention hashtag\" rel=\"tag\">#<span>NLG</span></a> <a href=\"https://discuss.systems/tags/NaturalLanguageGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>NaturalLanguageGeneration</span></a><br /><a href=\"https://discuss.systems/tags/TextGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>TextGeneration</span></a></p>", "contentMap": { "en": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>The next step in my feasibility study was to generate some English text. After examining some alternatives I selected SimpleNLG. A few tests convinced me that it would be a good basis.</p><p>However I was not happy with the way Java was being tortured. The main data structure was trees of lists of Java Objects - basically an unconstrained structure. A lot of the code consisted of tests of the type of Objects, which is an odd way to program a language which supports polymorphism. I did a rewrite in C++.</p><p>I added an RDF parser so that the input grammar tree can be supplied as an RDF Model. The result was able to complete the test cases provided for SimpleNLG.</p><p>This NLG is only able to create clauses and sentences so it will need to be wrapped in some other module to create the entire document. </p><p>This brings the story up to the present.</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a><br /><a href=\"https://discuss.systems/tags/NLG\" class=\"mention hashtag\" rel=\"tag\">#<span>NLG</span></a> <a href=\"https://discuss.systems/tags/NaturalLanguageGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>NaturalLanguageGeneration</span></a><br /><a href=\"https://discuss.systems/tags/TextGeneration\" class=\"mention hashtag\" rel=\"tag\">#<span>TextGeneration</span></a></p>" }, "attachment": [], "tag": [ { "type": "Hashtag", "href": "https://discuss.systems/tags/sassy", "name": "#sassy" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/softwarearchitecture", "name": "#softwarearchitecture" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/nlg", "name": "#nlg" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/naturallanguagegeneration", "name": "#naturallanguagegeneration" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/textgeneration", "name": "#textgeneration" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/112997725845159703/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/112997725845159703/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/112997725845159703/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/112997725845159703/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/112997725845159703/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/112993104764890632/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-20T07:12:31Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/112993104764890632", "type": "Note", "summary": null, "inReplyTo": "https://discuss.systems/users/ocratato/statuses/112981678302411581", "published": "2024-08-20T07:12:31Z", "url": "https://discuss.systems/@ocratato/112993104764890632", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/112993104764890632", "inReplyToAtomUri": "https://discuss.systems/users/ocratato/statuses/112981678302411581", "conversation": "tag:discuss.systems,2024-08-18:objectId=23759813:objectType=Conversation", "content": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>Having the design for a system in a knowledge database allows the use of tools to validate the design, and perhaps, even generate some aspects. </p><p>The downside is that humans don&#39;t speak RDF. SASSY will need mechanisms for getting the design information into and out of the knowledge database in a way that is easy for the average developer.</p><p>My research found a lot of work has been done over the decades to try and generate English text from the contents of a database. As far as I can tell none of it was very successful. If the data structure is well defined it is possible to use templates. Sadly the design of a software system is not going to be able to use a predefined structure. If the design has some features the template designer did not think of they would not be reported. A more flexible approach is required.</p><p>Thus the feasibility study was begun. I decided to work from the output back toward the database. This way each step would provide a specification for what the next one would need to create.</p><p>Step one was to create a nice PDF document. For this I used Pandoc to convert a Markdown document into PDF. Step two was to create an RDF description of the document and generate the Markdown. This worked better than I expected.</p><p>To be continued...</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a></p>", "contentMap": { "en": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>Having the design for a system in a knowledge database allows the use of tools to validate the design, and perhaps, even generate some aspects. </p><p>The downside is that humans don&#39;t speak RDF. SASSY will need mechanisms for getting the design information into and out of the knowledge database in a way that is easy for the average developer.</p><p>My research found a lot of work has been done over the decades to try and generate English text from the contents of a database. As far as I can tell none of it was very successful. If the data structure is well defined it is possible to use templates. Sadly the design of a software system is not going to be able to use a predefined structure. If the design has some features the template designer did not think of they would not be reported. A more flexible approach is required.</p><p>Thus the feasibility study was begun. I decided to work from the output back toward the database. This way each step would provide a specification for what the next one would need to create.</p><p>Step one was to create a nice PDF document. For this I used Pandoc to convert a Markdown document into PDF. Step two was to create an RDF description of the document and generate the Markdown. This worked better than I expected.</p><p>To be continued...</p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a></p>" }, "attachment": [], "tag": [ { "type": "Hashtag", "href": "https://discuss.systems/tags/sassy", "name": "#sassy" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/softwarearchitecture", "name": "#softwarearchitecture" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/112993104764890632/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/112993104764890632/replies?min_id=112997725845159703&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/112993104764890632/replies", "items": [ "https://discuss.systems/users/ocratato/statuses/112997725845159703" ] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/112993104764890632/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/112993104764890632/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/112991562025278559/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-20T00:40:10Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://discuss.systems/users/djmoch" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/112991562025278559", "type": "Note", "summary": null, "inReplyTo": "https://discuss.systems/users/djmoch/statuses/112988734151816542", "published": "2024-08-20T00:40:10Z", "url": "https://discuss.systems/@ocratato/112991562025278559", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://discuss.systems/users/djmoch" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/112991562025278559", "inReplyToAtomUri": "https://discuss.systems/users/djmoch/statuses/112988734151816542", "conversation": "tag:discuss.systems,2024-08-19:objectId=23806681:objectType=Conversation", "content": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://discuss.systems/@djmoch\" class=\"u-url mention\">@<span>djmoch</span></a></span> Ineresting. That defn seems to be based on &quot;Any sufficiently advanced technology is indistinguishable from magic&quot;</p><p>I tend to reserve the term for modules whose output data cannot possibly be derived from the available inputs - &quot;Magic happens here.&quot;</p>", "contentMap": { "en": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://discuss.systems/@djmoch\" class=\"u-url mention\">@<span>djmoch</span></a></span> Ineresting. That defn seems to be based on &quot;Any sufficiently advanced technology is indistinguishable from magic&quot;</p><p>I tend to reserve the term for modules whose output data cannot possibly be derived from the available inputs - &quot;Magic happens here.&quot;</p>" }, "attachment": [], "tag": [ { "type": "Mention", "href": "https://discuss.systems/users/djmoch", "name": "@djmoch" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/112991562025278559/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/112991562025278559/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/112991562025278559/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/112991562025278559/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/112991562025278559/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/112986368782523299/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-19T02:39:28Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/112986368782523299", "type": "Note", "summary": null, "inReplyTo": null, "published": "2024-08-19T02:39:28Z", "url": "https://discuss.systems/@ocratato/112986368782523299", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/112986368782523299", "inReplyToAtomUri": null, "conversation": "tag:discuss.systems,2024-08-19:objectId=23793869:objectType=Conversation", "content": "<p><a href=\"https://discuss.systems/tags/PriceGouging\" class=\"mention hashtag\" rel=\"tag\">#<span>PriceGouging</span></a> <br />The underlying reason is a lack of competition or market dominance.</p><p>Perhaps we need a market share tax.</p>", "contentMap": { "en": "<p><a href=\"https://discuss.systems/tags/PriceGouging\" class=\"mention hashtag\" rel=\"tag\">#<span>PriceGouging</span></a> <br />The underlying reason is a lack of competition or market dominance.</p><p>Perhaps we need a market share tax.</p>" }, "attachment": [], "tag": [ { "type": "Hashtag", "href": "https://discuss.systems/tags/pricegouging", "name": "#pricegouging" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/112986368782523299/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/112986368782523299/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/112986368782523299/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/112986368782523299/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/112986368782523299/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/112981678302411581/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-18T06:46:37Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/112981678302411581", "type": "Note", "summary": null, "inReplyTo": null, "published": "2024-08-18T06:46:37Z", "url": "https://discuss.systems/@ocratato/112981678302411581", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/112981678302411581", "inReplyToAtomUri": null, "conversation": "tag:discuss.systems,2024-08-18:objectId=23759813:objectType=Conversation", "content": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>An introduction to my SASSY project. Its name is short for Software Architecture Support System. The basic idea is to store the architectural design for software projects in a knowledge database so that the information is available for anyone that needs it.</p><p>My motivation was seeing too many projects where the design was unmaintained, inconsistent, incomplete, or simply non-existent.</p><p>Storing the information in a knowledge database would allow the construction of tools to highlight issues with the design. </p><p>My first attempt at prototyping SASSY used OWL for the knowledge database, with Protege as the user interface and Java code to create reports. While this did produce some nice results It was not a very friendly thing to use and was not flexible enough.</p><p>Now that I have time to spend on my own projects I have started a second attempt using RDF.</p><p>Web page for SASSY: <br /><a href=\"https://ocratato-sassy.sourceforge.io/\" target=\"_blank\" rel=\"nofollow noopener noreferrer\" translate=\"no\"><span class=\"invisible\">https://</span><span class=\"\">ocratato-sassy.sourceforge.io/</span><span class=\"invisible\"></span></a></p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a></p>", "contentMap": { "en": "<p><a href=\"https://discuss.systems/tags/SASSY\" class=\"mention hashtag\" rel=\"tag\">#<span>SASSY</span></a></p><p>An introduction to my SASSY project. Its name is short for Software Architecture Support System. The basic idea is to store the architectural design for software projects in a knowledge database so that the information is available for anyone that needs it.</p><p>My motivation was seeing too many projects where the design was unmaintained, inconsistent, incomplete, or simply non-existent.</p><p>Storing the information in a knowledge database would allow the construction of tools to highlight issues with the design. </p><p>My first attempt at prototyping SASSY used OWL for the knowledge database, with Protege as the user interface and Java code to create reports. While this did produce some nice results It was not a very friendly thing to use and was not flexible enough.</p><p>Now that I have time to spend on my own projects I have started a second attempt using RDF.</p><p>Web page for SASSY: <br /><a href=\"https://ocratato-sassy.sourceforge.io/\" target=\"_blank\" rel=\"nofollow noopener noreferrer\" translate=\"no\"><span class=\"invisible\">https://</span><span class=\"\">ocratato-sassy.sourceforge.io/</span><span class=\"invisible\"></span></a></p><p><a href=\"https://discuss.systems/tags/SoftwareArchitecture\" class=\"mention hashtag\" rel=\"tag\">#<span>SoftwareArchitecture</span></a></p>" }, "attachment": [], "tag": [ { "type": "Hashtag", "href": "https://discuss.systems/tags/sassy", "name": "#sassy" }, { "type": "Hashtag", "href": "https://discuss.systems/tags/softwarearchitecture", "name": "#softwarearchitecture" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/112981678302411581/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/112981678302411581/replies?min_id=112993104764890632&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/112981678302411581/replies", "items": [ "https://discuss.systems/users/ocratato/statuses/112993104764890632" ] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/112981678302411581/likes", "type": "Collection", "totalItems": 0 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/112981678302411581/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/112976095857729509/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-17T07:06:55Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/112976095857729509", "type": "Note", "summary": null, "inReplyTo": null, "published": "2024-08-17T07:06:55Z", "url": "https://discuss.systems/@ocratato/112976095857729509", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/112976095857729509", "inReplyToAtomUri": null, "conversation": "tag:discuss.systems,2024-08-17:objectId=23721549:objectType=Conversation", "content": "<p><a href=\"https://discuss.systems/tags/introduction\" class=\"mention hashtag\" rel=\"tag\">#<span>introduction</span></a></p><p>I am a retired software architect who is now messing about with impossible software projects.</p><p>My current crazy idea is to develop something that uses a knowledge database to store the architectural design for large software projects. I have called this project SASSY, and will post more on it later.</p><p>Other things that get my attention are astrophysics, old sci-fi movies, and dabbling in electronics.</p>", "contentMap": { "en": "<p><a href=\"https://discuss.systems/tags/introduction\" class=\"mention hashtag\" rel=\"tag\">#<span>introduction</span></a></p><p>I am a retired software architect who is now messing about with impossible software projects.</p><p>My current crazy idea is to develop something that uses a knowledge database to store the architectural design for large software projects. I have called this project SASSY, and will post more on it later.</p><p>Other things that get my attention are astrophysics, old sci-fi movies, and dabbling in electronics.</p>" }, "attachment": [], "tag": [ { "type": "Hashtag", "href": "https://discuss.systems/tags/introduction", "name": "#introduction" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/112976095857729509/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/112976095857729509/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/112976095857729509/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/112976095857729509/likes", "type": "Collection", "totalItems": 6 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/112976095857729509/shares", "type": "Collection", "totalItems": 0 } } }, { "id": "https://discuss.systems/users/ocratato/statuses/112974504089977858/activity", "type": "Create", "actor": "https://discuss.systems/users/ocratato", "published": "2024-08-17T00:22:07Z", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://hachyderm.io/users/nick_tune" ], "object": { "id": "https://discuss.systems/users/ocratato/statuses/112974504089977858", "type": "Note", "summary": null, "inReplyTo": "https://hachyderm.io/users/nick_tune/statuses/112972993801168687", "published": "2024-08-17T00:22:07Z", "url": "https://discuss.systems/@ocratato/112974504089977858", "attributedTo": "https://discuss.systems/users/ocratato", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://discuss.systems/users/ocratato/followers", "https://hachyderm.io/users/nick_tune" ], "sensitive": false, "atomUri": "https://discuss.systems/users/ocratato/statuses/112974504089977858", "inReplyToAtomUri": "https://hachyderm.io/users/nick_tune/statuses/112972993801168687", "conversation": "tag:hachyderm.io,2024-08-16:objectId=181547134:objectType=Conversation", "content": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://hachyderm.io/@nick_tune\" class=\"u-url mention\">@<span>nick_tune</span></a></span> All of the above would be my approach.</p><p>Put the legacy specific parts of the ACL in the Legacy system where it can be developed using existing legacy code by the developers familiar with that system.</p><p>Similarly for the new system. A separate ACL module can then handle the stuff that is independent of both the old and new systems.</p>", "contentMap": { "en": "<p><span class=\"h-card\" translate=\"no\"><a href=\"https://hachyderm.io/@nick_tune\" class=\"u-url mention\">@<span>nick_tune</span></a></span> All of the above would be my approach.</p><p>Put the legacy specific parts of the ACL in the Legacy system where it can be developed using existing legacy code by the developers familiar with that system.</p><p>Similarly for the new system. A separate ACL module can then handle the stuff that is independent of both the old and new systems.</p>" }, "attachment": [], "tag": [ { "type": "Mention", "href": "https://hachyderm.io/users/nick_tune", "name": "@nick_tune@hachyderm.io" } ], "replies": { "id": "https://discuss.systems/users/ocratato/statuses/112974504089977858/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://discuss.systems/users/ocratato/statuses/112974504089977858/replies?only_other_accounts=true&page=true", "partOf": "https://discuss.systems/users/ocratato/statuses/112974504089977858/replies", "items": [] } }, "likes": { "id": "https://discuss.systems/users/ocratato/statuses/112974504089977858/likes", "type": "Collection", "totalItems": 1 }, "shares": { "id": "https://discuss.systems/users/ocratato/statuses/112974504089977858/shares", "type": "Collection", "totalItems": 1 } } } ] }