NeuralSVG: An Implicit Representation for Text-to-Vector Generation

sagipolaczek.github.io

773 points by lnyan 6 days ago


vipshek - 6 days ago

This is excellent!

I think the utility of generating vectors is far, far greater than all the raster generation that's been a big focus thus far (DALL-E, Midjourney, etc). Those efforts have been incredibly impressive, of course, but raster outputs are so much more difficult to work with. You're forced to "upscale" or "inpaint" the rasters using subsequent generative AI calls to actually iterate towards something useful.

By contrast, generated vectors are inherently scalable and easy to edit. These outputs in particular seem to be low-complexity, with each shape composed of as few points as possible. This is a boon for "human-in-the-loop" editing experiences.

When it comes to generative visuals, creating simplified representations is much harder (and, IMO, more valuable) than creating highly intricate, messy representations.

janalsncm - 6 days ago

I am a huge fan of this type of incremental generative approach. Language isn’t precise enough to describe a final product, so generating intermediate steps is very powerful.

I’d also like to see this in music generation. Tools like Suno are cool but I would much rather have something that generates MIDIs and instrument configurations instead.

Maybe this is a good lesson for generative tools. It’s possible to generate something that’s a good starting point. But what people actually want is long tail, so including the capability of precision modification is the difference between a canned demo and a powerful tool.

> Code coming soon

The examples are quite nice but I have no idea how reproducible they are.

scosman - 6 days ago

I’ve been impressed with even applying sonnet to SVGs for animations. This looks like it could be a lot more powerful.

Fun example: https://gist.github.com/scosman/701275e737331aaab6a2acf74a52...

intalentive - 5 days ago

I’ve always thought that generation of intermediate representations was the way to go. Instead of generating concrete syntax, generate AST. Instead of generating PNG, generate SVG. Instead of generating a succession of images for animation, generate wire frame or rigging plus script.

Once you have your IR, modify and render. Once you have your render, apply a final coat of AI pixie dust.

Maybe generative models will get so powerful that fine-grained control can be achieved through natural language. But until then, this method would have the advantages of controllability, interoperability with existing tools (like Intellisense, image editors), and probably smaller, cheaper models that don’t have to accommodate high dimensional pixel space.

andy_ppp - 6 days ago

I’m looking forward to seeing what this makes of Simon Willison’s LLM SVG generation test prompt: “Generate an SVG of a pelican riding a bicycle”.

It’s quite amazing the progress we are seeing in AI and it will keep getting better which is somewhat terrifying.

goeiedaggoeie - 6 days ago

This is very nice.

I has to convert a bitmask to svg and was wishing to skip the intermediatary step so looked around for papers about segmentation models outputting svg and found this one https://arxiv.org/abs/2311.05276

zellyn - 6 days ago

The sketch generation is wild… and apparently comes for free.

airstrike - 6 days ago

This opens up lots of opportunities for document authoring tools. Really cool stuff, can't wait to try out the code once it's available.

jonathaneunice - 6 days ago

Nice! Looking forward to similar textual generation of diagrams. (The Pic/Pikchr for the LLM age.)

murtio - 6 days ago

This is really cool! I have been using Claude to animate SVG, and it has been great.

chestervonwinch - 5 days ago

I wonder if you can use an existing svg as a starting point. I would love to use the sketch approach and generate frame-by-frame animations to plot with my pen plotter.

CyberDildonics - 5 days ago

If you can generate an image you can flatten it and if you can flatten it you can cluster it, and if you can cluster the flat sections you can draw vectors around them.

Jean-Papoulos - 5 days ago

This is the kind of image generation I've been waiting for. No more messing around in Inkscape (or at least, less of it) when I need a specific icon.

TeMPOraL - 6 days ago

Available in ComfyUI when? :).

Seriously though, this is amazing, I'm glad to see this tackled directly.

Also, I just learned from this thread that Claude is apparently usable for generating SVGs (unlike e.g. GPT-4 when I tested for it some months ago), so I'll play with that while waiting for NeuralSVG to become available.

toisanji - 6 days ago

This is a group applying vector generation to animations: https://www.youtube.com/@studyturtlehq The graphic fidelity has been slowly improving over time.

theckel - 4 days ago

Does anyone know how this compares to: https://github.com/ximinng/SVGDreamer ?

niemandhier - 5 days ago

It looks as if this is not autoregressive.

It would be interesting to see a similar approach that incrementally works from simpler ( fewer curves ) to more complex representations.

That way one could probably apply RLHF along the trajectory too.

thomasfl - 5 days ago

Finally something that can benefit artists as a sketching tool.

cyp0633 - 5 days ago

Claude has been doing a good job generating SVGs compared to its rivals, happy to see new models bringing image generation even further

shahzaibmushtaq - 5 days ago

I am really impressed with how it generates rough sketches because everything in the design world begins that way.

nbzso - 5 days ago

So designers, artist, musicians we are done, right? Who's next, I wonder?

IncreasePosts - 5 days ago

Shouldn't the girl with the pearl earring have an earring?

piombisallow - 5 days ago

This is much more useful for actual design jobs.

nikolayasdf123 - 5 days ago

very nice. had this idea for awhile, but never had time to implement it.

glad someone actually did it! great work!

kelseyfrog - 6 days ago

Why does the fourth example show a hamburger but is labeled as a dragon?

pizza - 6 days ago

Prompting Claude to make SVGs then dropping them into Inkscape and getting the last ~20% of it to match the picture in my head has been a phenomenal user experience for me. This, too, piques my curiosity..!

fosterbuster - 6 days ago

Its a wasted opportunity not using SVG to show the examples.

1970-01-01 - 6 days ago

Aside: I've been having a very hard time prompting ChatGPT to spit out ASCII art. It really seems to not be able to do it.

     Here is an ASCII art representation of a hopping rabbit:

     ```
      (\(\  
      ( -.-)  
      o_(")(")
     ```

     This is a simple representation of a rabbit with its ears up and in a hopping stance. Let me know if you'd like me to adjust it!
lbj - 6 days ago

"Code coming soon" - I hope someone reposts this when there's more to dig into

dheera - 6 days ago

[flagged]

knoxg - 6 days ago

[flagged]