Joep Meindertsma - Atomic Data
S01:E01

Joep Meindertsma - Atomic Data

Episode description

One of the issues with today’s internet is that a lot of data is siloed. Consequently, users are locked into Big Tech ecosystems and its hard to reuse data. Joep Meindertsma, CEO of Ontola.io, talks about how his project Atomic Data addresses this problem with LinkedData. The free and open source project is a modular specification for sharing, modifying and modeling data. It uses links to connect pieces of data which makes it easier to connect datasets - even when these datasets exist on separate machines.

Inspired by Tim Berners-Lee, Joep works on an iteration of the semantic web that enforces JSON compatibility and type safety.

He also talks about the effect of NGI Zero funding on Atomic Tables and has some advice for people who are considering to apply for an NGI Zero grant.

Links mentioned in the episode:

Download transcript (.srt)
0:00

Welcome to the NGI Zero podcast where we talk to the people who are building the next

0:10

generation internet.

0:11

Hi, I'm Ronny Lam.

0:14

And I'm Tessel Renzenbrink.

0:16

We both work for NLnet, a foundation which financially supports people working on free

0:21

and open source technologies.

0:24

Today we're joined by Joep Meindertsma.

0:26

He is the CEO of Ontola IO, a Dutch software development firm that aims to give people

0:32

more control over their data.

0:34

He has received NGI Zero funding for three separate projects, Solid Search, Atomic Data

0:40

and Atomic Tables.

0:42

These are the projects we will talk about today.

0:44

Welcome Joep, and thanks for joining.

0:48

Awesome, looking forward to it.

0:51

Did we miss anything in our introduction?

0:54

I think that pretty much sums it up.

0:57

Maybe for some extra background, I started off with doing online democracy stuff about

1:03

10 years ago, and from there on slowly migrated towards doing more with data ownership and

1:09

open data, but we'll probably dive into that soon.

1:13

Sure, yeah, indeed.

1:16

Your projects are all about modeling and connecting data.

1:20

What are the key issues with how data is used on the web today?

1:25

I think one of the biggest issues at this point is that a lot of data is siloed, and

1:30

this is partly because a lot of big tech companies are designing their systems to have data siloed.

1:36

What that basically means is that it's very hard to reuse data.

1:40

What that means is that users get locked into an ecosystem.

1:43

There's a very concrete example of this.

1:46

I'm locked into the Google ecosystem.

1:48

I have a Gmail account.

1:50

I have a Google calendar.

1:51

It integrates everywhere.

1:52

I have a Google Drive thing, and that kind of limits how easy it is for me to switch

1:58

to some sort of competitor, and this really limits the degree of innovation, and it also

2:05

makes me very dependent on what Google does.

2:08

Google has a large control over my life.

2:11

It can serve me ads and manipulate me.

2:15

It can have a large impact on how my software world looks like.

2:21

I think that there's a lot of reasons why we should want to have more control over our

2:24

data, but it's just difficult.

2:27

The main reason that it's difficult is not necessarily only because these big tech companies

2:31

are trying to lock us in, but also because it's very difficult to make open tools that

2:37

work well with each other.

2:38

Of course, there's an open source email tool, and of course, there's an open source calendar

2:42

tool, and there's an open source this and this and that.

2:45

But every time somebody makes some sort of open source tool, they not only have to make

2:50

that tool open and really good, but they also have to make sure it works well with people's

2:54

data.

2:55

That's basically the fundamental limitation, in my view, of how many of these applications

3:00

work nowadays is that they don't really work well together.

3:04

So the issue that as a software engineer you have is when you're designing an application,

3:09

you also have to design its API, its programming interface.

3:13

When you do that, it's very tempting to just design the thing that you need at that point

3:18

in time.

3:20

But that also means that if somebody wants to use that API, they'll have to read your

3:23

specification, they have to understand how you've been thinking about this.

3:27

And many APIs are vastly different.

3:29

So one of the things that I was trying to solve with first with linked data and later

3:34

with Atomic Data is to make one API that's highly standardized, very readable, very browsable,

3:41

and very highly interoperable so that at some point in the future, people could make

3:46

their own applications that work well together.

3:49

And one of the cool things you can do if you have a very well-defined API is that you can

3:54

have decentralized data.

3:56

So you can have data that's stored in a different server somewhere else in the world, and you

4:01

can point to it using a link, and you can reuse that.

4:04

So for example, let's say I'm going to plan a wedding event, and I have a lot of lists

4:12

of attendees of people who I want to invite to my wedding.

4:15

And I have this wedding event concept where I want people to be able to RSVP, but I also

4:21

want a lot of information from people like, are you a vegetarian?

4:25

What's your profile picture?

4:27

What's your phone number maybe or email address?

4:29

And are you taking a plus one?

4:31

All of these questions.

4:33

What would be really nice if I could just point to someone's URL, like I would point

4:38

to your URL, and that URL would contain all this information like, what's your profile

4:43

picture?

4:44

What's your name, et cetera.

4:45

And that's basically what linked data promise has been about in the past few decades, but

4:51

wasn't really achieved because it was just too much of a hassle for developers.

4:57

So that's why I started working about four years ago on Atomic Data, which is a very

5:02

strict subset of linked data, which enforces JSON compatibility.

5:08

Most developers use JSON as a serialization format.

5:11

And it also enforces type safety, which means that if you have like a date field for your

5:15

birth date, for example, that's standardized in how it's written, like year, year, year,

5:20

month, month, date, date.

5:21

So you can't like, you know which data type it is, which is very useful for software engineers.

5:26

And the third thing it does is enable this decentralized data approach.

5:29

You use URLs.

5:31

So it's basically a very long monologue for the main problem that I've been working on

5:36

and how I'm trying to solve it with Atomic Data specification.

5:39

Yeah, thanks.

5:41

That really clarifies things.

5:43

But just for people who are not really super into this field, can you maybe go back a little

5:52

and explain what the semantic web is and what RDF is and what Atomic Data does to improve

6:00

on RDF?

6:01

So the inventor of the World Wide Web is Tim Berners-Lee.

6:04

And he made the first websites, the first website and the first web browser and the

6:10

first web server back in, I think, 88 or 89.

6:14

And at some point in time, he realized that websites are nice, they're documents.

6:20

But what you want is that a URL, like the link to websites, doesn't just represent a

6:24

document, but it can represent a person.

6:26

It can represent an event.

6:27

It can represent anything.

6:29

And that's when he started working on the semantic web, right?

6:33

Where the web is linked with semantic meanings.

6:36

So you have like a person and they have a friend, right?

6:40

And this friend is another link somewhere which has its own data.

6:43

So that's basically the goal of the semantic web.

6:47

And the semantic web is expressed using this language basically called RDF, which is the

6:52

Resource Description Framework.

6:54

And it was introduced in the 90s.

6:55

It was based on XML and it never really took off.

7:00

Like nobody's actually using RDF in production.

7:03

But this dream of having a semantic web where all machines are connected to each other and

7:07

people can reuse data and this data is extremely machine readable.

7:12

I really love that dream.

7:14

So my software company, Ontola, had this product called Argue, which is this e-democracy platform

7:20

we talked earlier about.

7:22

And we went all in on RDF, right?

7:24

So we basically made our whole stack linked data RDF stuff.

7:29

But at some point, we became really frustrated and we saw some of the fundamental limitations

7:33

of RDF.

7:34

And that's basically when I was thinking, OK, I need to constrain this.

7:37

I need to make it a smaller subset.

7:39

I need to make it a little bit tighter.

7:41

So it's easy to work with as a software engineer.

7:44

And that's what Atomac Data is.

7:45

It's like this is making this semantic web useful for software engineers and for developers.

7:51

That's like when I'm talking about JSON compatibility and type safety.

7:55

I know this is already becoming pretty technical.

7:58

So I'm sorry if you're listening to this and you think, what was this guy talking about?

8:02

How is it taking off?

8:04

Are other people adopting this?

8:08

That's an interesting question because when I started out with Atomic Data, I first wrote

8:14

the specification, right?

8:15

I had like this 70 page document just detailing how the specification would work.

8:22

And it's just an idea and nothing happens, right?

8:24

Like nobody's going to make something if you just have a specification.

8:27

So what you need is a specification plus an implementation.

8:31

That's why I started working on what I thought would be the best killer application, which

8:36

is Atomic Server.

8:37

And Atomic Server is basically, I'm not sure if you're familiar with Notion, but like this

8:42

all in one workspace app where you have documents, but you also have tables.

8:46

So in a way, it's like Microsoft Excel plus Microsoft Word merged into one user friendly

8:51

application.

8:52

So I wanted to make that, but using Atomic Data as basically the core and make it fully

8:59

open source and free for everyone and make it really, really performant.

9:03

So I wrote it in Rust, which is a really nice programming language for making these performance

9:06

system applications.

9:08

Atomic Server became basically this database with a very easy to use front end, which people

9:13

can use to manage their data.

9:16

And that's basically the main use for Atomic Data right now is that application implementation.

9:21

So what I'm trying to do now is basically build a community around that implementation.

9:25

So people start using it for their own projects.

9:28

And we have a bunch of front end libraries which people can use to implement it in their

9:32

apps.

9:33

So there's like a React library, there's a Svelte library, there's a Node.js library.

9:39

So like a lot of tools for developers to help them get started.

9:42

But because it's all JSON, you don't even need to use these libraries.

9:45

You can just use your whatever framework you're already using and just fetch the data straight

9:50

from Atomic Server.

9:51

And really the goal is to make it really easy for developers to start using this in their

9:56

production apps.

9:58

I think it's really interesting what you're saying that you cannot just write a specification,

10:02

but that you also have to do an implementation.

10:04

And you did a lot of implementation already.

10:09

Yeah, that's true.

10:10

I think I was mainly inspired by Tim Berners-Lee.

10:13

So he did the same thing with when he started the World Wide Web.

10:16

He's like, okay, I wrote this specification for the World Wide Web with, you know, HTTP

10:20

and HTML.

10:22

But the only reason it took off is because he also wrote an open source server and an

10:26

open source browser.

10:28

And so he had the specification server and browser.

10:30

I did the same thing for Atomic.

10:33

Because I think that's like a recipe that could work.

10:36

The specification still has to prove itself, right?

10:38

Other people also have to like it to some extent.

10:42

And that's kind of the difficult part is convincing developers to also use this.

10:49

But that's why I'm focusing so much on the implementation, just to have like a very good

10:52

open source database.

10:54

Because if you have a good open source database, you can just use it without the benefits of

10:58

Atomic Data.

11:00

But as more and more projects are using that, at some point, the interoperability between

11:04

these projects is going to be a huge selling point.

11:07

So I'm hoping that we get like this S curve adoption, right?

11:09

So first you have a couple of projects using atomic data.

11:12

And at some point, a lot of people are using it and they can point to each other and you

11:15

get like this accelerating effect, same as the World Wide Web growth, right?

11:19

You get this network effect and then it can really pick up steam.

11:24

Yeah, I also want to congratulate you on your on your documentation.

11:29

I mean, it's it's super.

11:33

It's huge.

11:34

It's well written.

11:35

It's understandable.

11:36

I think not enough people pay so much attention to documentation.

11:44

Is this something that is specifically important to you?

11:47

Is it something you like to do?

11:49

How come you do it so well?

11:51

Oh, thanks.

11:53

To be honest, I'm not entirely very happy about all the documentation.

11:56

I mean, some things of it are good and I'm a bit proud of, but there's also like still

12:01

a lot of gaps.

12:02

Because I think documentation writing isn't very fun compared to application writing.

12:06

I think that's like one of the biggest hurdles.

12:09

So what I often tend to do is to structure my thoughts using my writing and that becomes

12:16

documentation.

12:17

So if I'm thinking about, oh, I need to solve like this problem, then I just start writing

12:22

the documentation basically and use it as part of a process.

12:26

So that for me makes it a little bit easier to to to make something.

12:30

So in a way, that's like documentation driven development.

12:33

Right.

12:33

So you have like a couple of software development paradigms.

12:35

Some people do test driven development and this is documentation driven development.

12:39

And the advantage of that is that you end up with an API that's very easy to explain

12:44

because you basically start with the explanation of how you can use it.

12:48

And then at some point you've built it and then other developers who look at it,

12:51

hopefully it feels understandable because otherwise you make something that's

12:56

logical to program, but maybe harder to use.

13:00

And is or may be one of your goals to to to put this into a standard.

13:08

I mean, you you wrote a specification, but I it's your hope to get this into a real

13:15

standard.

13:16

So I think what's what the specification is, is to some extent, it already is a standard.

13:23

So when I started off, I also named it a standard.

13:27

And then somebody called me and said, hey, listen, this is not a standard.

13:31

I'm like, but but it's a specification, right.

13:33

And it standardizes something.

13:35

He says, yes, but for it to be a standard, it has to be adopted.

13:38

So I think, yes, that's exactly my goal.

13:40

I want it to be a standard.

13:41

I want it for I want people to use it.

13:43

So then it kind of becomes a standard.

13:45

And that probably also includes making the specification even stricter and tighter

13:50

because like at some point there's going to be some sort of ambiguity that's inside

13:53

the documentation already.

13:54

It's going to be very obvious if people are going to make their own applications on it

13:58

or their own server implementations, for example, that are slightly different.

14:02

So this is like one of the challenges is if you build an implementation is that it's very

14:06

tempting for the implementation to basically get further than the documentation because

14:13

it's very tempting to just add this new feature or this cool thing.

14:16

And if you don't document it, well, then it's kind of out there and it becomes a de facto

14:21

specification, even though it's not written down.

14:23

So that's like, I think, a pitfall.

14:26

And is that is that the way you work?

14:29

You first write your specification and you then develop your application to it?

14:37

For pretty much.

14:38

Yeah, for most things, that's how I prefer to work.

14:41

That's definitely the case at very early days of Atomic Server development, which is like

14:46

I was on vacation in Switzerland and I was just on my laptop all day.

14:50

My girlfriend hated it because I wasn't really enjoying the vacation as much, but I was in

14:54

this flow where I just writing Atomic Server and writing the documentation.

14:59

And nowadays, what I often do is I first write an issue in GitHub, very detailed issue,

15:05

explore a couple of approaches and a couple of APIs, and then I build it.

15:09

Because now I'm at a point where the specification is not changing a lot

15:14

and the implementation is changing mostly because like specific endpoints,

15:17

specific plugins, specific added features that the documentation is pretty stable.

15:23

Just to follow up on Ronny's question.

15:25

So you want it to be adopted, but are you planning on going through like a standards

15:31

body to get it adopted as a standard?

15:35

So the Atomic Data is a W3C working group, which in a sense means that there is already

15:43

some sort of process in there for it to become a standard.

15:47

I also reached out to a body that is concerning media type standards.

15:53

I forgot like the body doing the MIME types.

15:57

But at some point, I also became a little bit frustrated with the bureaucracy of some

16:02

of these processes.

16:03

And I saw that there are some really, really effective standards or specifications that is

16:07

they're widely adopted, but they're not documented in such a group.

16:11

So then I became more, I was more like, okay, if I just document it well and I make the process

16:16

open and transparent, then I don't necessarily have to adhere to some very bureaucratic

16:21

external process at this point.

16:24

But maybe later it becomes necessary, like as it grows and more people are using it.

16:29

I do think that's the point.

16:31

I would like to make a NGI Zero plug here because we don't only give grants to great projects,

16:37

but we also support with practical support.

16:40

And one of our partners in the NGI Zero coalition is Tolerant Networks.

16:47

And they have very much a lot of experience with standardization bodies.

16:52

And especially this point that you mentioned, like it's super slow and difficult and you

16:56

need to speak to the right people.

16:58

And they can, if you are interested, or maybe you can send somebody else to do it if you

17:03

don't like it, but they can really help you with taking the steps.

17:08

I mean, they can't do it for you, but they can definitely give you advice on it.

17:12

And this is also for anybody listening who wants this kind of support than NGI Zero.

17:18

Oh, this sounds actually really useful.

17:20

So I'm 100% going to do this.

17:23

Nice.

17:25

I also have another question.

17:27

And this is more from the perspective of people who are using the web.

17:30

So of course you are directed mostly toward developers.

17:34

But what would a person who is using the web, what would Atomic Data be like for them?

17:42

Would the web experience change or would it be like under the hood and they would hardly

17:46

notice or?

17:48

I think if it works well, if it's like widely adopted and many services use it, at some

17:53

point, many things are going to start to feel like magic.

17:56

Like your calendar is just completely integrated with all these other services and it just

18:03

works.

18:05

You can have like one list of contacts and they are automatically updated in terms of

18:09

their profile picture and new data arises.

18:12

And you only get access to people who actually want you to have access and you get the

18:18

fields that you should get access to.

18:21

I think you can have like completely open source social media platforms that have a timeline

18:27

that don't order based on what advertisers want.

18:32

So Facebook, they have like an AI trained to maximize engagement and make you click

18:37

on as much ads as possible.

18:39

You can have like your own algorithm for social media feed.

18:43

So for example, I would like to have a social media feed that helps me understand the world

18:47

as good as possible and keeps me up to date on important events and have some sort of

18:52

neutrality not to be too much biased in a certain direction.

18:55

And maybe someone else could pick their own algorithm that they would want for their

18:59

social media feed.

19:00

I think the open source social media direction is very interesting and I hope it can make

19:05

polarization in our society a little less worse.

19:10

And I can also imagine that it just removes a bunch of hassle.

19:13

So like if you have your Google Photos, right, there's a lot of photos stored there and at

19:17

some point you just want a different front end.

19:19

You have like this other app and it works really nice.

19:21

You want to migrate to it.

19:23

Well, with Atomic Data, that should be completely trivial because you can just change the front

19:27

end of an app without moving your data.

19:29

Your data just is yours.

19:31

It's on your server somewhere.

19:32

And as an additional benefit to that, that means things are really, really fast.

19:37

So if you use Atomic Server, which if you're listening to this and you want to try it,

19:41

it's just a one-liner Docker command.

19:43

It's a 12 megabytes binary executable.

19:45

It's very, very easy to install.

19:47

You'll notice that it's ridiculously fast.

19:50

Like there's nothing on the web, like pretty much not a single app that you've used that

19:54

is this fast.

19:55

And I like fast applications.

19:57

I like that things open instantly.

19:58

And with Atomic Server, like when you're searching through all of your data, like every key press

20:03

performs a search and within like seven or 20 milliseconds, you get like a full response

20:08

back.

20:09

So you'll feel very productive.

20:11

And I think that's also a big plus.

20:14

That's a nice bridge to our next question, which is, I mean, if people are interested,

20:22

how can they get involved?

20:24

What do they have to do to work with Atomic Data?

20:28

I think the easiest path for people to work with it is to just install Atomic Server

20:33

somewhere.

20:33

And that's like probably the easiest with the Docker image.

20:35

So like I said, like a one-liner, no external dependencies or whatever.

20:40

And if then people actually want to make an application, there's a couple of libraries.

20:44

So we have like a React library, a Svelte library, an Atomiclib library for other JS

20:49

applications.

20:50

There's a template for React applications.

20:53

There's also a template for Svelte websites, which basically is an entire website, which

20:57

is already linked to Atomic Server.

20:59

So there's a couple of ways people can get started.

21:01

But I think the biggest one is to join the Discord server, because we have like a Discord

21:05

server.

21:07

You can just ask your question there.

21:09

I'd love to help you.

21:10

There's other people who help as well.

21:12

And it's, I think, a very good place to just share your idea and get some feedback and

21:16

start working on this.

21:18

What are the next steps for the project?

21:21

So at this point, the project lacks some important features for me that I think limited to

21:27

becoming a very useful headless CMS.

21:30

So a headless CMS is basically the number one proposition I'm trying to achieve with

21:34

the Atomic Server application, which is basically...

21:38

Can you explain what a headless CMS is?

21:40

Yes.

21:40

So a headless CMS is basically a thing where you store content for the web.

21:46

It's a content management system.

21:48

So WordPress, for example, I think many people are familiar with WordPress, which you use

21:52

for building websites.

21:53

That is a CMS, but it has a head as well, which is the front end.

21:58

And the headless CMS is only the backend stuff, but without the front end.

22:01

So you can design the web page all the way you want, any way you want.

22:05

And the headless CMS basically deals with all the data.

22:08

It's a place where you can sign in and edit your web pages.

22:11

You can search your things.

22:13

And I really want to make that proposition really well.

22:15

So we have this proposition mostly aimed at software engineers who want to make websites.

22:19

So we have a couple of features that are still missing, which are currently being prioritized.

22:23

One of them is an improved document editor, which should feel similar to Obsidian.

22:29

Not sure if you're familiar with that, but it's like this markdown, what you see is what you mean.

22:34

kind of text editor, which I feel like is very productive.

22:38

And we're building things like a form interface where you can create a form web page,

22:44

where you can just make submissions without creating a user or whatever, just for guest entries.

22:48

For example, for surveys or for a contact form for your website or a reservation for your restaurant.

22:55

These types of things is what forms are about.

22:57

So better document support, better form support are two top priorities.

23:02

And the newest things right now is basically the table editor and the data model editor,

23:06

the ontology editor, which was done using the NGI Zero grant.

23:10

So thank you a lot for that.

23:12

And it seems a lot of stuff is happening.

23:16

I looked at your roadmap and it's like every month there's a new thing being built.

23:21

Can you tell me something about the team that's behind this?

23:25

Who are the people working on this?

23:28

At this point, the team working on Atomic Server is pretty small, actually.

23:31

It's me and Polle Pas.

23:33

So Paul Opass also works at Ontola.

23:35

He's mostly working on the front end.

23:38

So if you see something in the front end that's good and well designed,

23:42

chances are pretty high that he did that.

23:46

And I'm mostly doing the backend stuff.

23:49

But we're both doing a bit backend and a bit frontend as well.

23:53

And there's also now a couple of people who have been contributing to the repository,

23:56

which to me, that's like the most magical thing.

23:59

If you have an open source project and there's some random person you've never heard of

24:03

and they're improving your code base and asking how the testing suite works or something,

24:09

when that happens, I just feel all warm and fuzzy inside.

24:12

It's really magical.

24:14

That's when the adoption starts.

24:16

Yeah, yeah, absolutely.

24:19

Well, the next question was, what do you like most about working on your project?

24:23

But maybe that was the answer.

24:25

Yes, I think that a feeling of community when people start using something,

24:30

that's one of the most magical and good feelings.

24:33

I also really like it when things come together and they are simple.

24:37

So I really have a strong distaste for complexity in software projects

24:43

or having too many components.

24:45

And if you make something that feels very lightweight and easy to understand

24:49

and easy to set up and it has a little amount of dependencies,

24:53

that also feels very, very good.

24:55

But I'm not sure if other people will feel the same about that,

24:58

but I feel that's a very strong guiding force in how we write software.

25:02

To zoom out again a little to the semantic web more generally,

25:08

what do you think is needed?

25:11

Because it sounds like there are a lot of positive sides to it.

25:16

So what would be needed in the rest of the world to get the semantic web going?

25:23

I think that's a good question because if I look at just the semantic web

25:29

and the RDF specification, it has a couple of these big limitations,

25:33

which I feel will make it impossible to be really big.

25:37

So we have RDF and the SOLID project.

25:40

I've also been a contributor to SOLID and worked quite closely

25:43

even with Tim Berners-Lee a couple of years ago.

25:46

But at some point I just felt like this isn't going to be the thing

25:49

that I want it to be.

25:51

It's too technically complex.

25:52

It's too difficult for software engineers to make something.

25:54

So I feel like what the semantic web needs is type safety,

25:58

JSON support and a clear consistent protocol.

26:02

And these are the three things I think that Atomic Data has solved and has now added.

26:08

I do think that there's still some things that Atomic Data is probably missing,

26:13

like good OAuth support.

26:17

So I think that's a big one I also want to work on in the near future.

26:22

And what we're also missing is just implementations,

26:24

just people toying with it and creating their own apps.

26:28

Because the only way it really takes off is if we are seeing the start of this S curve

26:32

and you get these network effects.

26:35

And I think that there's a couple of domains where that makes more sense than in other domains,

26:40

mostly personal data, personal document management, event management, event registration, RSVPs.

26:47

I think these specifically would benefit a little bit extra from having open...

26:53

Yeah, having an implementation for atomic server.

26:57

And the people who are now listening, how can they contribute to making the semantic web

27:04

a thing that's going to be?

27:07

Oh yeah.

27:09

I think one of the biggest things you can do is just make simple apps.

27:17

Just make simple, useful apps for yourself.

27:19

Just make some sort of short demonstration.

27:21

Just make it like a weekend project, toy around with it a bit.

27:25

And demonstrate to people that this is something that you can play with

27:30

and actually use it for something that you want.

27:32

So maybe you want to import your playlist from Spotify

27:36

and have a playlist manager for your music.

27:39

That's not a very complex application,

27:41

but it's a very fun process to make something like that.

27:45

Or make a tool for your resume.

27:50

Make a resume editor and use that in Atomic Data

27:53

and share the data models that you've created.

27:56

So one of the big things for Atomic Data is that the data models that you create

28:00

are also URLs, which you can reuse.

28:02

So other people can reuse your data models.

28:04

And as that happens, you get like this standardization effect.

28:07

But that does require that people start making some of these data models

28:10

and spreading them and using them in applications.

28:13

That's like the magic of the network effect that still has to happen.

28:16

How did the NGI Zero grant help you reach your goals for your project?

28:23

It has a huge effect because I have a very small software company.

28:28

And we basically get to choose how we spend our time,

28:32

depending on how the money flows.

28:37

So we would love to work on an open source tool,

28:41

like completely MIT licensed, without having some sort of paid service attached to it,

28:49

to just make that available for people.

28:51

And that's basically only possible through grants and subsidies

28:55

to bootstrap that process.

28:57

Because it takes a while, even for an open source tool,

28:59

to get it to a point where you get like user adoption.

29:04

And you can use the grant to bootstrap adoption.

29:07

And from there on, at some point, get an investor

29:10

to build towards a revenue model that's sustainable.

29:13

So what NGI Zero for me did was enable this first path, basically,

29:17

this first place in the process where you can do your fundamental research

29:21

and you can build the open source tool and you can get your first amount of users.

29:25

And from there on, you can try to basically scale it up and turn it into a service.

29:30

But what I really wanted to do is to first focus on having a good specification,

29:34

having a good open source implementation.

29:36

And that's basically impossible if the first thing that you need to do

29:39

is to find customers and get a consistent revenue flow.

29:43

Because then you're going to focus on a lot of different things.

29:45

And I think that the open source character is going to be left behind if you do that.

29:49

So for me, it's essential in developing something with this kind of business model.

29:53

Yeah, agreed.

29:55

What advice would you give to people considering to apply for funding?

30:03

Yeah, focus on community.

30:05

I think that is such a big thing.

30:07

Just set up a Discord server for your project and invite people to that, link to it everywhere.

30:15

And every time somebody joins, just reach out to them

30:18

and talk about what makes them enthusiastic about technology.

30:22

Because these individual connections that I had with people

30:24

have been so incredibly inspiring and rewarding.

30:27

Because the first people who are going to join such a community

30:30

are probably one of the most innovative, interesting people that you'll ever meet.

30:35

So I feel like just set up an infrastructure for your community to grow.

30:39

Do everything in public.

30:41

Just write your thoughts in GitHub issues.

30:44

Because there's a small chance that other people are going to read it.

30:46

And if they do, these are the most important people for your project to grow.

30:51

So yeah, community, community, community.

30:55

True.

30:56

I think we're getting to the end of our questions at least.

31:00

Is there anything you would still like to say?

31:03

Yeah, I want to say thank you so much for making this all possible.

31:07

I think that it's pretty rare for software engineers to be able to do something like this,

31:13

right?

31:13

To basically receive income for working on completely open source tools just for a more open web.

31:20

And I think without the role that you play in this ecosystem,

31:23

it would be very, very difficult to make meaningful changes.

31:27

So yeah, thank you so much for that you're working on this.

31:29

I really appreciate it.

31:31

Well, and we'd like to return that because we'd like to

31:34

thank you for working on improving the internet.

31:36

Oh, thank you.

31:39

I think that's it for this podcast.

31:43

So we'll leave it here.

31:44

And Joep, thank you very much for joining us today

31:47

and sharing all the interesting things about your project.

31:51

Well, thank you so much for having me.

31:52

It's been a blast.