Profile

I'm a software engineer with 10 years of experience building enterprise applications, infrastructure, and leading technical teams. I am proficient in Python, C#, and C++ for backend and standalone applications, and have experience with cloud providers, primarily AWS. Working in startups has also given me hands-on experience in frontend technologies

I hold a Master's in Artificial Intelligence and a Bachelor’s in Software Engineering. Alongside my academic knowledge of AI, I have professional experience with LLMs, prompt engineering, and RAG techniques to enhance contextual understanding and code generation. I'm also interested in blockchain and decentralized systems, driven by my concerns for freedom, democracy, censorship resistance, and transparency.

I'm passionate about clean code, software design, testing, architecture, and CI/​CD, with a focus on delivering high-quality products that meet the needs of both customers and stakeholders. My colleagues often describe me as responsible, kind, and diligent. For more on my professional focus and teaching approach, check out my course on Continuous Delivery.

Skills
Programming and Markup Languages

Python, C#, C++, Rust, JavaScript, HTML, CSS, SQL, UML

Key Techniques and Principles

Software architectures, Cryptography, BFT consensus algorithms, Blockchain, DeFi, Object-oriented design, Unit testing, Data structures, Algorithms, CI/​CD, Computer networks, Compiler design, Acceptance testing, Machine learning, Concurrent programming, Domain-driven design, LLMs, RAG, Monorepo

Libraries and Frameworks

ASP.NET MVC, FastAPI, Boto3, Entity Framework, pytest, Flask, Django, Bootstrap, jQuery, Xamarin, SphinX, Keras, Tensorflow, NUnit, Langchain

Tools and Applications

AWS, Localstack, DynamoDB, SQL Server, Redis, PostgreSQL, Docker, Protobuf, gRPC, ELK Stack, Kafka, Neo4J, LLMs, Pinecone, Jenkins, GitLab CI, GitHub Actions, Redash, Jira, ANTLR

Work Experience
2024 – PresentRemote, Oman
Software Engineer and Consultant | Consensus Protocol and Decentralized Exchange (Python), Zellular

As a software engineer and protocol consultant for the Zellular BFT sequencer, my responsibilities include:

  • Researching and applying BFT consensus protocols (PBFT, Tendermint, HotStuff variants, SmartBFT, FastBFT, etc.) to drive high-throughput, low-latency BFT protocol.
  • Shaping safety/​liveness reasoning and the validation strategy using BFT testing/​proof practices (e.g., twin-testing concepts).
  • Building and iterating on a protocol PoC in Python and integrating it with EigenLayer validators/​restaking to exercise realistic validator participation.
  • Driving performance work that reaches 100k+ tx/sec throughput with <1s latency in the PoC.
  • As a consultant for Zellular Exchange (a DEX built on the Zellular BFT protocol), I focus on:

  • Delivering AWS cloud-native solutions for data-intensive requirements, including database design (using DynamoDB and Aurora PostgreSQL) and orchestration (using EKS).
  • Leading requirements engineering and defining measurable acceptance criteria across performance, reliability, availability, and security.
  • Guiding architecture and component design for high-load systems (using microservices and Kubernetes patterns) and async exchange flows (using Kafka), with production-grade observability (using Prometheus and OpenTelemetry).
  • Defining CI/​CD and GitOps operations (using GitHub Actions and Argo CD).
  • Designing acceptance tests (using Gherkin) and load testing (using Locust) hierarchies and scenarios.
  • 2023 – PresentRemote, Australia
    Software Engineer | Backend and AI Engine (Python), BIMLOGIQ

    As a Software Engineer on the "Copilot" product team—an AI assistant plugin for Autodesk Revit—I play a key role in both development and operations:

  • Design and implementation of full-cycle CI/CD pipelines using GitLab CI, including unit testing, code style checks, type checking, acceptance testing, model training, benchmarking, publishing and deployment, artifact management, and reporting stages.
  • Conducting technical interviews to assess the software engineering skills of candidates, as well as mentoring and onboarding them.
  • Developing the AI engine, including connecting REST services to the engine layer, managing data testing pipelines, prompts engineering, and developing AI and RAG techniques using the Langchain library.
  • Working with and benchmarking various LLMs and chat models, including OpenAI GPT series, Vertex AI (Gemini, others), Anthropic models, and Groq models (LLaMA3, Gemma, Mixtral, etc.).
  • Collaborating with the frontend team to develop and maintain APIs using FastAPI on AWS Lambda, ensuring efficient communication protocols and seamless integration.
  • Handling the database architecture and data management using Amazon DynamoDB, focusing on performance, scalability, and data integrity.
  • Managing and monitoring the entire backend infrastructure using AWS services such as Lambda, DynamoDB, CloudWatch, Load Balancer, EC2, ECS, S3, SNS, IAM, API Gateway, Bedrock, and more, ensuring system reliability and security.
  • Setting up caching mechanisms for faster retrieval and chat model responses by configuring Redis on AWS NLB/EC2/ECS.
  • Producing BI reports using Redash to inform strategic decisions and operational improvements.
  • 2019 – 2023Hybrid, Iran
    Software Engineer and Team Leader | Quality Assurance and DLP Libraries (Python and C++), Mahsan

    I led the company's QA team, responsible for developing services, frameworks, infrastructures, rules, and metrics to enhance the quality of department products. I held both management and technical development responsibilities, including:

  • Managing a team of seven developers and DevOps engineers, organizing tasks, and providing guidance.
  • Conducting 100+ tech interviews, leading to 10+ high-value hires.
  • Teaching courses on CI/CD, DevOps, testing, clean code, object-oriented design, mono repo, and living documents.
  • Developing a requirement engineering and acceptance testing framework for company products with a vast requirements state space, utilizing libraries like Jinja2, lxml, Click, GoJS, Rivets.js, and Lark.
  • Creating an infrastructure management application to set up the products' environments at various stages. It cooperates with Docker and Terraform, manages resources with Neo4j, and offers REST (using FastAPI) and gRPC APIs.
  • Building an automatic network traffic generation application that is utilized by other products. The application generates traffic for 3000 different scenarios and tens of applications simultaneously (using Selenium and Appium).
  • Establishing department's Python standards: repository management (using Pantsbuild and tox), documentation (using SphinX), code style (using flake8, isort, Pylint, Black), typing (using Mypy), and testing (using pytest).
  • Defining and measuring quality metrics/​levels for other projects.
  • Supplying Jenkins CI/CD and JFrog Artifactory support to teams.
  • Understanding C++ concepts, compilers (GCC and Clang/LLVM), tools (e.g. CMake, Ninja, Doxygen, Protobuf, cpplint), and libraries (e.g. Boost). Also, developing unit tests (using Google Test and gMock) and testable C++ applications.
  • Presenting unit testing practices (test doubles, fixtures, parameterized testing, etc.) to other teams resulted in full test coverage for all new features and 2000+ regression tests to the department's main product over time.
  • 2015 – 2019Hybrid, Iran
    Software Engineer | Web and Mobile (C#), Resaa

    Given the startup nature of the project, as a full-stack developer, I contributed to various projects, including the website (visit https://resaa.net), admin panel, telegram bots, and internal/​external services, plus the doctor-side mobile app. My activities included:

  • Developing websites and services, encompassing solution projects and layers (using Visual Studio and MSBuild concepts), backends (using ASP.NET MVC and ASP.NET WebAPI), and frontends (using HTML, Bootstrap, CSS, JS, and jQuery). I also worked on bot state machines, caching mechanisms (using Redis), databases (using Microsoft SQL Server), and ORM (the Entity Framework) setups. Additionally, I was involved in logging processes (using NLog and Sentry) and unit testing (using NUnit).
  • Developing the doctor-side mobile application (using Xamarin) for Android, iOS, and UWP platforms. This involved managing data persistence (using SQLite) and architectural design (using Prism and MVVM pattern).
  • Actively participating in business meetings and engaging directly with doctors.
  • Initially, the project involved around 10 doctors and 100 patients, but by the end of my tenure, the system had expanded to approximately 500 doctors and 10,000 actively using patients.
  • Education
    2018 – 2020Iran
    M.Sc. in Artificial Intelligence, Sharif University of Technology
  • GPA: 3.97/​4
  • Deep learning and Machine learning courses TA
  • 2014 – 2018Iran
    B.Sc. in Computer Software Engineering, University of Tehran
  • GPA: 3.88/​4
  • Advanced programming, Compiler design, and Computer network courses TA
  • ACM magazine editor
  • Awards
    First place in the M.Sc. program among all AI field students

    Maintaining the first rank for two years with a total score of 3.97.

    First place in the B.Sc. program among all engineering fields students

    Maintaining the first rank for four years with a total score of 3.88.

    Third place in the 15th National Khwarizmi Youth Festival

    Third place in the 15th Khwarizmi Youth Festival for software application with the title of "Authentication System Based on Behavioral Patterns".

    Publications