AI News 2024-06-06

Research Insights

  • Guiding a Diffusion Model with a Bad Version of Itself combines an image model with an intentionally worse version of itself, and shows how this combination can be used for image synthesis that better balances coherence vs. diversity. (Despite neural methods being largely “block boxes”, results like this show that we do actually understand enough about internals to make meaningful interventions.)
  • LLMs are notoriously bad at math. A new preprint investigates fixing that: Transformers Can Do Arithmetic with the Right Embeddings.
    • The model can do 100-digit addition (99% accuracy) after being trained on 20-digit numbers. Capabilities also adapted to multiplication. The trick is to enforce an embedding that explicitly captures the position of digits within a number. So numerical representations are first-class during tokenization (conceptually similar to the Polymathic xVal number encoding).
    • Of course LLMs can just call external functions to make sure math gets done correctly. But I like the idea of crafting the LLMs themselves to correctly embody basic concepts from math and logic, as it might generalize to improved performance on a range of other planning/deliberation activities.

Audio

  • Machine translation has been scaled to 200 languages. The impressive part is that many of these languages have very little training data. The point is that the model can learn language structure from the well-represented languages, and generalize to the languages will less training data.

Avatars

AI audio/video avatars are advancing rapidly. (So this is your periodic reminder to be increasingly skeptical of videos you see, and of random phone calls from loved ones asking you for money.)

  • Synthesia EXPRESS-1 avatars show emotions that match the text.
  • HeyGen has also demonstrated that they can apply their AI avatar trick (resync lip motions in an existing video to match a new script) to videos where the person is in motion. One of the main use-cases is converting videos to other languages; so this broadens the range of content that can be targeted. Of course one can also use it to nefariously change what someone said in an otherwise very-non-AI-looking video.
  • V-Express improves further on virtual avatars (generates video aligned with an audio track, based on a single photo).
  • ChatTTS is a text-to-speech system that is remarkably good, including being able to add natural-sounding pauses, laughs, etc. Open source, so you can run it all locally if you want.

Posted in AI, News | Tagged , , , | Leave a comment

How to break apart Python pathlib Paths?

Python pathlib is the modern way to handle file paths. But I always forget how to break apart a path into components (directory part, filename part, etc.). This image is a cheat-sheet for working with Path, breaking it apart into root, directory path, filename, suffix, etc.

Posted in Helpguide | Leave a comment

How to convert dates/times in Python?

Working with dates and times in Python often involves converting between the various possible representations. Here is a graphic to quickly lookup how to convert between the different formats (epoch, struct_time, Python datetime object, string representation, and matplotlib date convention).

Posted in Helpguide | Leave a comment

Quarantine Email

Awhile ago, I wrote some code to graph my email behavior (in the spirit of Stephen Wolfram). I have been teleworking for the last 11 weeks (due to COVID19), and was curious to see how this shows up in my email behavior. First let’s start with a baseline by looking at average behavior over the last 5 years.

This is a stacked plot, with email I send (purple, bottom), and email I receive (blue for internal email, green for external).

There are many caveats. This is work email only. I am (intentionally) only measuring archived email, and exclude spam or any email that I delete rather than archive. This leads to the ‘sent’ (which is always saved) being much larger than ‘received’ (since I only archive things that are useful, not the thousands of emails generated every time someone needs to schedule a meeting). The data has some artifacts related to changes in how the lab has managed email over the years (and changes in my threshold for delete vs. archive). Nevertheless, it gives us something to consider.

The overall increase in email volume over time is apparent. The dip at the end of December each year of course coincides with holidays. We can also look at the average distribution of email over the course of a week:

Emails obviously come in mostly during working hours (though there is plenty of off-hours traffic from automated systems, other time zones, and colleagues who just aren’t sensible). My email sending follows clear patterns, including how I set aside weekday morning to handle backlogs of low-priority requests. Now we can compare during-quarantine to before-quarantine.

What changes do we see? I am receiving less external email than usual (not surprising, given how many collaborations are currently on hold). Email both sent and received is less contained to normal working hours. This is due both to crisis-management activities, and the blending of work and life.

Posted in Data | Tagged , , , , , | Leave a comment

New Layout

I have moved the website over to WordPress.

Posted in News | 1 Comment