Some checks are pending
CI / Lint and Format (push) Waiting to run
CI / Test Python 3.11 on macos-latest (push) Waiting to run
CI / Test Python 3.12 on macos-latest (push) Waiting to run
CI / Test Python 3.13 on macos-latest (push) Waiting to run
CI / Test Python 3.10 on ubuntu-latest (push) Waiting to run
CI / Test Python 3.11 on ubuntu-latest (push) Waiting to run
CI / Test Python 3.12 on ubuntu-latest (push) Waiting to run
CI / Test Python 3.13 on ubuntu-latest (push) Waiting to run
CI / Security Scan (push) Waiting to run
CI / Build Package (push) Blocked by required conditions
Add intelligent analysis and recommendation tools for KiCad designs: ## New AI Tools (kicad_mcp/tools/ai_tools.py) - suggest_components_for_circuit: Smart component suggestions based on circuit analysis - recommend_design_rules: Automated design rule recommendations for different technologies - optimize_pcb_layout: PCB layout optimization for signal integrity, thermal, and cost - analyze_design_completeness: Comprehensive design completeness analysis ## Enhanced Utilities - component_utils.py: Add ComponentType enum and component classification functions - pattern_recognition.py: Enhanced circuit pattern analysis and recommendations - netlist_parser.py: Implement missing parse_netlist_file function for AI tools ## Key Features - Circuit pattern recognition for power supplies, amplifiers, microcontrollers - Technology-specific design rules (standard, HDI, RF, automotive) - Layout optimization suggestions with implementation steps - Component suggestion system with standard values and examples - Design completeness scoring with actionable recommendations ## Server Integration - Register AI tools in FastMCP server - Integrate with existing KiCad utilities and file parsers - Error handling and graceful fallbacks for missing data Fixes ImportError that prevented server startup and enables advanced AI-powered design assistance for KiCad projects. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
36 lines
956 B
Python
36 lines
956 B
Python
"""
|
|
Component layout management for KiCad schematics.
|
|
|
|
Stub implementation to fix import issues.
|
|
"""
|
|
|
|
from dataclasses import dataclass
|
|
|
|
|
|
@dataclass
|
|
class SchematicBounds:
|
|
"""Represents the bounds of a schematic area."""
|
|
x_min: float
|
|
x_max: float
|
|
y_min: float
|
|
y_max: float
|
|
|
|
def contains_point(self, x: float, y: float) -> bool:
|
|
"""Check if a point is within the bounds."""
|
|
return self.x_min <= x <= self.x_max and self.y_min <= y <= self.y_max
|
|
|
|
|
|
class ComponentLayoutManager:
|
|
"""Manages component layout in schematic."""
|
|
|
|
def __init__(self):
|
|
self.bounds = SchematicBounds(-1000, 1000, -1000, 1000)
|
|
|
|
def get_bounds(self) -> SchematicBounds:
|
|
"""Get the schematic bounds."""
|
|
return self.bounds
|
|
|
|
def validate_placement(self, x: float, y: float) -> bool:
|
|
"""Validate if a component can be placed at the given coordinates."""
|
|
return self.bounds.contains_point(x, y)
|