outlines VS hof

Compare outlines vs hof and see what are their differences.

hof

Framework that joins data models, schemas, code generation, and a task engine. Language and technology agnostic. (by hofstadter-io)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
outlines hof
33 35
5,799 477
11.0% 1.3%
9.7 8.5
6 days ago 7 days ago
Python Go
Apache License 2.0 Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

outlines

Posts with mentions or reviews of outlines. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-05-05.
  • Infini-Gram: Scaling unbounded n-gram language models to a trillion tokens
    4 projects | news.ycombinator.com | 5 May 2024
    > [2]: https://github.com/outlines-dev/outlines?tab=readme-ov-file#...

    It's interesting as speech recognition has become more popular than ever through services like Alexa, and other iot devices support for OS speech recognition

    Unfortunately most implementations (especially those that are iot focused) don't have very important features for robust speech recognition.

    1. Ability to enable and disable a grammar

  • Show HN: LLM-powered NPCs running on your hardware
    4 projects | news.ycombinator.com | 30 Apr 2024
    [4] https://github.com/outlines-dev/outlines/tree/main
  • Advanced RAG with guided generation
    2 projects | dev.to | 18 Apr 2024
    The next step is defining how to guide generation. For this step, we'll use the Outlines library. Outlines is a library for controlling how tokens are generated. It applies logic to enforce schemas, regular expressions and/or specific output formats such as JSON.
  • Anthropic's Haiku Beats GPT-4 Turbo in Tool Use
    5 projects | news.ycombinator.com | 8 Apr 2024
    No benchmarks, just my anecdotal experience trying to get local LLM's to respond with JSON. The method above works for my use case nearly 100% of the time. Other things I've tried (e.g. `outlines`[0]) are really slow or don't work at all. Would love to hear what others have tried!

    0 - https://github.com/outlines-dev/outlines

  • Show HN: Chess-LLM, using constrained-generation to force LLMs to battle it out
    1 project | news.ycombinator.com | 14 Mar 2024
    As I was playing with the Outlines library (https://outlines-dev.github.io/outlines/), I discussed with my friend Maxime how funny it would be if we set up a way to pair LLMs in chess matches till one wins. The first time I tried it, it required substantial prompt engineering to get some of those LLMs to propose valid moves. Large language models can mostly stay focused and even play rather well; see https://news.ycombinator.com/item?id=37616170 for example. However small language models aren't as easy to convince.

    Some of those LLMs have seen very little chess notation and so after the first few opening moves there aren't any valid tactics, let alone strategy, so they would end up either repeating the same move, or hallucinate moves that are not valid (Kxe5, but there would be a queen on e5!)

    Then Outlines came along and we could force them to pick valid moves with little cost! Maxime worked super fast and got a first version of this idea as a gradio space.

    I think it is pretty fun to see the (mostly terrible, but otherwise valid) chess that those LLMs play. Maybe it will even be instructive to how we can create small LLMs that can play much better than the ones on the leaderboard.

    Anyway, you can check it out here:

    https://huggingface.co/spaces/mlabonne/chessllm

    What is interactive about it: you can pick the LLMs from available models on HuggingFace (within reason, small LLMs are preferable so that the space does not crash) or push one of your own small models to HF and have it fight with others. At the end of the game the leaderboard is updated.

    Hope you find it fun!

  • Show HN: Prompts as (WASM) Programs
    9 projects | news.ycombinator.com | 11 Mar 2024
    > The most obvious usage of this is forcing a model to output valid JSON

    Isn't this something that Outlines [0], Guidance [1] and others [2] already solve much more elegantly?

    0. https://github.com/outlines-dev/outlines

    1. https://github.com/guidance-ai/guidance

    2. https://github.com/sgl-project/sglang

  • Show HN: Fructose, LLM calls as strongly typed functions
    10 projects | news.ycombinator.com | 6 Mar 2024
  • Unlocking the frontend – a call for standardizing component APIs pt.2
    8 projects | dev.to | 5 Mar 2024
    And I think “just” Markdown doesn’t quite cut it for safe guidance. For example: directly generating content for your components. But I’m really excited about tooling like outlines appearing, with a greater focus on guided generation for structured data. Because this is often what we actually need!
  • Ask HN: What are some actual use cases of AI Agents?
    6 projects | news.ycombinator.com | 14 Feb 2024
    It's pretty easy to force a locally running model to always output valid JSON: when it gives you probabilities for the next tokens, discard all tokens that would result in invalid JSON at that point (basically reverse parsing), and then apply the usual techniques to pick the completion only from the remaining tokens. You can even validate against a JSON schema that way, so long as it is simple enough.

    There are a bunch of libraries for this already, e.g.: https://github.com/outlines-dev/outlines

  • Launch HN: AgentHub (YC W24) – A no-code automation platform
    2 projects | news.ycombinator.com | 8 Feb 2024
    https://github.com/outlines-dev/outlines/blob/7fae436345e621... squares with my experience using LLMs for anything real

      sequence = generator("Alice had 4 apples and Bob ate 2. Write an expression for Alice's apples:")

hof

Posts with mentions or reviews of hof. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-05-06.
  • Looking for help with transpiling TypeScript to Golang and Python using LLMs
    4 projects | news.ycombinator.com | 6 May 2024
    For a auth product, you probably should go with traditional code generation, not LLMs (re: all the unsolvable problems they have (hallucinations, incomplete code answers). For an auth product, you want something definite and reproducible, or you are asking for trouble.

    If you are interested in a flexible code gen framework, I built one that had this very use case in mind. (https://github.com/hofstadter-io/hof)

    I'd be happy to think / talk this through with you

  • Ask HN: Interesting TUIs (text user interfaces), maybe forgotten ones?
    56 projects | news.ycombinator.com | 6 May 2024
    I recently built a TUI for exploring and developing CUE, JSON, Yaml.

    Large inspiration for the overall UX comes from the Bloomberg terminal, where every function is reachable with four letter shortcut from the command box. It was really the command box that I liked. I've also built a sort of "flex" panel component for the layout so you can create as many panels as you like.

    https://docs.hofstadter.io/getting-started/hof-tui/

    https://github.com/hofstadter-io/hof/tree/_dev/lib/tui

  • Ask HN: Are SQL developers generally familiar with JSON, VSCode and Docker?
    1 project | news.ycombinator.com | 14 Mar 2024
    Many business analysts use SQL, have for a long time. They are probably not your target audience. With the problem being JAVA specific, you'd likely want to start there

    This sounds similar to the goals of my hof tool (https://github.com/hofstadter-io/hof), lift type definitions out of code so they can be defined in one place, then generate the code for all the places. Is that sounding like what you are after?

  • Show HN: Open SaaS – An open-source alternative to paid boilerplate starters
    6 projects | news.ycombinator.com | 30 Jan 2024
    Having built something similar, the biggest challenge for users is that they have to use a bespoke language, like WASP here. I suspect that it is also your biggest challenge as well.

    Mine is built on CUE, which at least has the potential to become a more widely used language. CUE hasn't reached sufficient maturity for broader adoption yet, so I continue to face this same problem.

    https://github.com/hofstadter-io/hof

  • OpenAI: Prompt Engineering
    5 projects | news.ycombinator.com | 15 Dec 2023
    Here's a big one I needed to get ChatGPT to do something more sophisticated with a JSON object response (predates functions and all that)

    https://github.com/hofstadter-io/hof/blob/_dev/flow/chat/pro...

    It no longer worked after a model update some time ago, haven't tried recently.

    I found codellama to be much better for this and require fewer instructions, an anecdotal validation for smaller, focussed models

  • Ask HN: What's the most compelling AI prompt result you've seen?
    1 project | news.ycombinator.com | 28 Nov 2023
    I was surprised out how you can define arbitrary grammars using arbitrary formulation and it would follow it. Of course you have to redo the prompt every time there is an update... such a pain

    https://github.com/hofstadter-io/hof/blob/_dev/flow/chat/pro...

  • HTTPie Desktop: cross-platform API testing client for humans
    18 projects | news.ycombinator.com | 8 Oct 2023
    CUE is indeed a beautiful language, will get those mind juices flowing for sure!

    There is more work to be done on the codec implementation, but if you just want to split yaml/json across files, CUE is a great option

    You might also like my project, built on CUE: https://github.com/hofstadter-io/hof We have a TUI where you can explore and work with CUE, JSON, Yaml

  • Show HN: A tool to Convert JSON schemas into TypeScript classes
    7 projects | news.ycombinator.com | 5 Oct 2023
    You can pretty much make up any pseudo grammar like this one, which is a reduced JSON object that is close to CUE: https://github.com/hofstadter-io/hof/blob/_dev/flow/chat/pro...

    No need to be formal or use a standard format

  • Guidance: A guidance language for controlling large language models
    10 projects | news.ycombinator.com | 16 Sep 2023
    Yea, in particular for this project, they have created a bespoke templating system.

    You can get the same thing with Go text/templates by adding chat function(s) as custom a helper: https://github.com/hofstadter-io/hof/blob/_dev/lib/templates...

  • Textual Web: TUIs for the Web
    9 projects | news.ycombinator.com | 7 Sep 2023
    100% one of the best things about building a TUI is not having the pain of modern web development. I do think there is a way to have a CLI & TUI come from the same code, so you can get the best of both, or pick the best for the task at hand.

    experiments in progress here: https://github.com/hofstadter-io/hof/tree/_dev/lib/tui

What are some alternatives?

When comparing outlines and hof you can also consider the following projects:

guidance - A guidance language for controlling large language models.

cue - The home of the CUE language! Validate and define text-based and dynamic configuration

jsonformer - A Bulletproof Way to Generate Structured JSON from Language Models

smug - Session manager and task runner for tmux. Start your development environment within one command.

json-schema-spec - The JSON Schema specification

ping-heatmap - A tool for displaying subsecond offset heatmaps of ICMP ping latency

Constrained-Text-Genera

go-live - 🗂️ go-live is an ultra-light server utility that serves files, HTML or anything else, over HTTP.

torch-grammar

jk - Configuration as Code with ECMAScript

langroid - Harness LLMs with Multi-Agent Programming

bashly - Bash command line framework and CLI generator