GitHub Repository Forum RSS-Newsfeed

Egs002+proteus+library+install Now

A language for humans and computers

Examples

Crystal is a general-purpose, object-oriented programming language. With syntax inspired by Ruby, it’s a compiled language with static type-checking. Types are resolved by an advanced type inference algorithm.

# A very basic HTTP server
require "http/server"

server = HTTP::Server.new do |context|
  context.response.content_type = "text/plain"
  context.response.print "Hello world, got #{context.request.path}!"
end

address = server.bind_tcp(8080)
puts "Listening on http://#{address}"

# This call blocks until the process is terminated
server.listen

Batteries included

Crystal’s standard library comes with a whole range of libraries that let you start working on your project right away.

require "http/client"
require "json"

response = HTTP::Client.get("https://crystal-lang.org/api/versions.json")
json = JSON.parse(response.body)
version = json["versions"].as_a.find! { |entry| entry["released"]? != false }["name"]

puts "Latest Crystal version: #{version || "Unknown"}"

Type system

The compiler catches type errors early. Avoids null pointer exceptions at runtime.

The code is still clean and feels like a dynamic language.

def add(a, b)
  a + b
end

add 1, 2         # => 3
add "foo", "bar" # => "foobar"

Flow typing

The compiler tracks the type of variables at each point, and restricts types according to conditions.

loop do
  case message = gets # type is `String | Nil`
  when Nil
    break
  when ""
    puts "Please enter a message"
  else
    # In this branch, `message` cannot be `Nil` so we can safely call `String#upcase`
    puts message.upcase
  end
end

Concurrency Model

Crystal uses green threads, called fibers, to achieve concurrency. Fibers communicate with each other via channels without having to turn to shared memory or locks (CSP).

channel = Channel(Int32).new

3.times do |i|
  spawn do
    3.times do |j|
      sleep rand(100).milliseconds # add non-determinism for fun
      channel.send 10 * (i + 1) + j
    end
  end
end

9.times do
  puts channel.receive
end

C-bindings

Bindings for C libraries makes it easy to use existing tools. Crystal calls lib functions natively without any runtime overhead.

No need to implement the entire program in Crystal when there are already good libraries for some jobs.

# Define the lib bindings and link info:
@[Link("m")]
lib LibM
  fun pow(x : LibC::Double, y : LibC::Double) : LibC::Double
end

# Call a C function like a Crystal method:
puts LibM.pow(2.0, 4.0) # => 16.0

Macros

Crystal’s answer to metaprogramming is a powerful macro system, which ranges from basic templating and AST inspection, to types inspection and running arbitrary external programs.

macro upcase_getter(name)
  def {{ name.id }}
    @{{ name.id }}.upcase
  end
end

class Person
  upcase_getter name

  def initialize(@name : String)
  end
end

person = Person.new "John"
person.name # => "JOHN"

Dependencies

Crystal libraries are packed with Shards, a distributed dependency manager without a centralised repository.

It reads dependencies defined in shard.yml and fetches the source code from their repositories.

name: hello-world
version: 1.0.0
license: Apache-2.0

authors:
- Crys <crystal@manas.tech>

dependencies:
  mysql:
    github: crystal-lang/crystal-mysql
    version: ~>0.16.0

Egs002+proteus+library+install Now

You could just solder the real thing. But simulation is where you earn your stripes without releasing the magic smoke. Simulating the EGS002 allows you to:

But because the EG8010 is a specialized Chinese ASIC, it isn't native to Proteus. We need to import a third-party model.

Several hobbyist communities provide pre‑drawn EGS002 schematics/libraries: egs002+proteus+library+install

You will typically get two files:

| Issue | Cause | Solution | | :--- | :--- | :--- | | "Library Not Found" | Files placed in wrong directory or user lacks admin rights. | Verify path is ...\Proteus 8 Professional\LIBRARY. Run Proteus as Administrator. | | "No Model Specified" Error | Attempting to run a simulation without a SPICE file. | This is expected. Use the component for layout/design only, or import a SPICE model. | | Missing Pins | Library file is corrupt or incomplete. | Re-download the library or manually edit the device symbol in the library manager. | | Footprint Mismatch | The library creator used a non-standard package. | Open the "Packaging Tool" in Proteus and assign a standard SIL-XX header package. | You could just solder the real thing


Before we dive into the technical installation, let’s understand the component.

The "EGS002" is not a single chip. It is a module containing: But because the EG8010 is a specialized Chinese

In Proteus, we do not need the physical layout of the PCB. We need the electrical model. The custom library contains a composite part with pins for:

Without this library, you would have to build the EG8010 and IR2110 logic from discrete gates—a task that would take weeks. The custom library compresses 100+ components into one block.